Commit 5b2113e5 authored by Alexander Butenko's avatar Alexander Butenko

Merge pull request #5 from screeper/master

Added table prefix feature
parents fee1b126 e27b056b
......@@ -19,6 +19,12 @@ class MysqliDb
* @var MysqliDb
*/
protected static $_instance;
/**
* Table prefix
*
* @var string
*/
protected $_prefix;
/**
* MySQLi instance
*
......@@ -106,6 +112,7 @@ class MysqliDb
$this->port = $port;
$this->connect();
$this->setPrefix();
self::$_instance = $this;
}
......@@ -150,6 +157,16 @@ class MysqliDb
$this->count = 0;
}
/**
* Method to set a prefix
*
* @param string $prefix Contains a tableprefix
*/
public function setPrefix($prefix = '')
{
$this->_prefix = $prefix;
}
/**
* Pass in a raw query and an array containing the parameters to bind to the prepaird statement.
*
......@@ -214,7 +231,7 @@ class MysqliDb
$columns = '*';
$column = is_array($columns) ? implode(', ', $columns) : $columns;
$this->_query = "SELECT $column FROM $tableName";
$this->_query = "SELECT $column FROM $this->_prefix$tableName";
$stmt = $this->_buildQuery($numRows);
$stmt->execute();
$this->_stmtError = $stmt->error;
......@@ -248,7 +265,7 @@ class MysqliDb
*/
public function insert($tableName, $insertData)
{
$this->_query = "INSERT into $tableName";
$this->_query = "INSERT into $this->_prefix$tableName";
$stmt = $this->_buildQuery(null, $insertData);
$stmt->execute();
$this->_stmtError = $stmt->error;
......@@ -267,7 +284,7 @@ class MysqliDb
*/
public function update($tableName, $tableData)
{
$this->_query = "UPDATE $tableName SET ";
$this->_query = "UPDATE $this->_prefix$tableName SET ";
$stmt = $this->_buildQuery(null, $tableData);
$stmt->execute();
......@@ -287,7 +304,7 @@ class MysqliDb
*/
public function delete($tableName, $numRows = null)
{
$this->_query = "DELETE FROM $tableName";
$this->_query = "DELETE FROM $this->_prefix$tableName";
$stmt = $this->_buildQuery($numRows);
$stmt->execute();
......@@ -348,7 +365,7 @@ class MysqliDb
if ($joinType && !in_array ($joinType, $allowedTypes))
die ('Wrong JOIN type: '.$joinType);
$this->_join[$joinType . " JOIN " . $joinTable] = $joinCondition;
$this->_join[$joinType . " JOIN " . $this->_prefix.$joinTable] = $joinCondition;
return $this;
}
......
......@@ -10,6 +10,11 @@ After that, create a new instance of the class.
$db = new Mysqlidb('host', 'username', 'password', 'databaseName');
```
It's also possible to set a table prefix:
```php
$db->setPrefix('tablePrefix');
```
Next, prepare your data, and call the necessary methods.
### Insert Query
......
......@@ -5,6 +5,9 @@ error_reporting(E_ALL);
$db = new Mysqlidb('localhost', 'root', '', 'testdb');
if(!$db) die("Database error");
$prefix = 'prefix_';
$db->setPrefix($prefix)
$tables = Array (
'users' => Array (
'login' => 'char(10) not null',
......@@ -92,7 +95,7 @@ function createTable ($name, $data) {
foreach ($tables as $name => $fields) {
$db->rawQuery("DROP TABLE $name");
createTable ($name, $fields);
createTable ($prefix.$name, $fields);
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment