Commit 5eba6215 authored by Josh Campbell's avatar Josh Campbell

Added Features

parent 8f36a33f
#Mac OS X files
.DS_Store
#Vim leave-behinds
*.swp
\ No newline at end of file
<?php <?php
/**
class MysqlDB { * MySqliDb Class
*
protected $_mysql; * @category Database Access
protected $_where = array(); * @package MysqliDB
* @author Jeffery Way <jeffrey@jeffrey-way.com>
* @author Josh Campbell <josh.campbell@teslacity.com>
* @copyright Copyright (c) 2010 Jeffery Way
* @license http://opensource.org/licenses/gpl-3.0.html GNU Public License
* @version 1.1
**/
class MysqliDB {
protected static $_instance;
protected $_mysqli;
protected $_query; protected $_query;
protected $_where = array();
protected $_whereTypeList;
protected $_paramTypeList; protected $_paramTypeList;
protected $_crudType = null;
public function __construct($host, $username, $password, $db) { public function __construct($host, $username, $password, $db) {
$this->_mysql = new mysqli($host, $username, $password, $db) or die('There was a problem connecting to the database'); $this->_mysqli = new mysqli($host, $username, $password, $db)
or die('There was a problem connecting to the database');
self::$_instance = $this;
}
/**
* A method of returning the static instance to allow access to the
* instantiated object from within another class.
* Inheriting this class would require reloading connection info.
*
* @return object Returns the current instance.
*/
public static function getInstance()
{
return self::$_instance;
}
/**
* A method of returning the static instance.
*
* @return object Returns the current instance.
*/
protected function reset()
{
$this->_where = array();
unset($this->_query);
unset($this->_whereTypeList);
unset($this->_paramTypeList);
} }
/** /**
...@@ -18,12 +56,13 @@ class MysqlDB { ...@@ -18,12 +56,13 @@ class MysqlDB {
* @param int $numRows The number of rows total to return. * @param int $numRows The number of rows total to return.
* @return array Contains the returned rows from the query. * @return array Contains the returned rows from the query.
*/ */
public function query($query) public function query($query, $numRows = NULL)
{ {
$this->_query = filter_var($query, FILTER_SANITIZE_STRING); $this->_query = filter_var($query, FILTER_SANITIZE_STRING);
$stmt = $this->_buildQuery($numRows);
$stmt = $this->_prepareQuery();
$stmt->execute(); $stmt->execute();
$this->reset();
$results = $this->_dynamicBindResults($stmt); $results = $this->_dynamicBindResults($stmt);
return $results; return $results;
} }
...@@ -37,13 +76,13 @@ class MysqlDB { ...@@ -37,13 +76,13 @@ class MysqlDB {
*/ */
public function get($tableName, $numRows = NULL) public function get($tableName, $numRows = NULL)
{ {
$this->_crudType = 'read';
$this->_query = "SELECT * FROM $tableName"; $this->_query = "SELECT * FROM $tableName";
$stmt = $this->_buildQuery($numRows); $stmt = $this->_buildQuery($numRows);
$stmt->execute(); $stmt->execute();
$this->reset();
$results = $this->_dynamicBindResults($stmt); $results = $this->_dynamicBindResults($stmt);
return $results; return $results;
} }
...@@ -55,13 +94,13 @@ class MysqlDB { ...@@ -55,13 +94,13 @@ class MysqlDB {
*/ */
public function insert($tableName, $insertData) public function insert($tableName, $insertData)
{ {
$this->_crudType = 'insert';
$this->_query = "INSERT into $tableName"; $this->_query = "INSERT into $tableName";
$stmt = $this->_buildQuery(NULL, $insertData); $stmt = $this->_buildQuery(NULL, $insertData);
$stmt->execute(); $stmt->execute();
$this->reset();
if ($stmt->affected_rows) ($stmt->affected_rows) ? $result = $stmt->insert_id : $result = false;
return true; return $result;
} }
/** /**
...@@ -73,10 +112,12 @@ class MysqlDB { ...@@ -73,10 +112,12 @@ class MysqlDB {
*/ */
public function update($tableName, $tableData) public function update($tableName, $tableData)
{ {
$this->_crudType = 'update';
$this->_query = "UPDATE $tableName SET "; $this->_query = "UPDATE $tableName SET ";
$stmt = $this->_buildQuery(NULL, $tableData); $stmt = $this->_buildQuery(NULL, $tableData);
$stmt->execute(); $stmt->execute();
$this->reset();
if ($stmt->affected_rows) if ($stmt->affected_rows)
return true; return true;
} }
...@@ -87,23 +128,22 @@ class MysqlDB { ...@@ -87,23 +128,22 @@ class MysqlDB {
* @param string $tableName The name of the database table to work with. * @param string $tableName The name of the database table to work with.
* @return boolean Indicates success. 0 or 1. * @return boolean Indicates success. 0 or 1.
*/ */
public function delete($tableName) public function delete($tableName) {
{
$this->_crudType = 'delete';
$this->_query = "DELETE FROM $tableName"; $this->_query = "DELETE FROM $tableName";
$stmt = $this->_buildQuery(); $stmt = $this->_buildQuery();
$stmt->execute(); $stmt->execute();
$this->reset();
if ($stmt->affected_rows) if ($stmt->affected_rows)
return true; return true;
} }
/** /**
* This method allows you to specify a WHERE statement for SQL queries. * This method allows you to specify multipl WHERE statements for SQL queries.
* *
* @param string $whereProp A string for the name of the database field to update * @param string $whereProp The name of the database field.
* @param mixed $whereValue The value for the field. * @param mixed $whereValue The value of the database field.
*/ */
public function where($whereProp, $whereValue) public function where($whereProp, $whereValue)
{ {
...@@ -122,21 +162,21 @@ class MysqlDB { ...@@ -122,21 +162,21 @@ class MysqlDB {
protected function _determineType($item) protected function _determineType($item)
{ {
switch (gettype($item)) { switch (gettype($item)) {
case 'string': case 'string':
return 's'; return 's';
break; break;
case 'integer': case 'integer':
return 'i'; return 'i';
break; break;
case 'blob': case 'blob':
return 'b'; return 'b';
break; break;
case 'double': case 'double':
return 'd'; return 'd';
break; break;
} }
} }
...@@ -149,61 +189,79 @@ class MysqlDB { ...@@ -149,61 +189,79 @@ class MysqlDB {
* @param array $tableData Should contain an array of data for updating the database. * @param array $tableData Should contain an array of data for updating the database.
* @return object Returns the $stmt object. * @return object Returns the $stmt object.
*/ */
protected function _buildQuery($numRows = NULL, $tableData = false) protected function _buildQuery($numRows = NULL, $tableData = NULL)
{ {
$hasTableData = null; $hasTableData = false;
if (gettype($tableData) === 'array') { if (gettype($tableData) === 'array')
$hasTableData = true; $hasTableData = true;
}
// Did the user call the "where" method? // Did the user call the "where" method?
if (!empty($this->_where)) { if (!empty($this->_where))
$keys = array_keys($this->_where); {
$where_prop = $keys[0];
$where_value = $this->_where[$where_prop];
// if update data was passed, filter through and create the SQL query, accordingly.
// if update data was passed, filter through if ($hasTableData)
// and create the SQL query, accordingly. {
if ($hasTableData) {
$i = 1; $i = 1;
if ( $this->_crudType == 'update' ) { $pos = strpos($this->_query, 'UPDATE');
foreach ($tableData as $prop => $value) { if ( $pos !== false)
{
foreach ($tableData as $prop => $value)
{
// determines what data type the item is, for binding purposes. // determines what data type the item is, for binding purposes.
$this->_paramTypeList .= $this->_determineType($value); $this->_paramTypeList .= $this->_determineType($value);
// prepares the reset of the SQL query. // prepares the reset of the SQL query.
if ($i === count($tableData)) { ($i === count($tableData)) ?
$this->_query .= $prop . " = ? WHERE $where_prop = '$where_value'"; $this->_query .= $prop . ' = ?':
} else {
$this->_query .= $prop . ' = ?, '; $this->_query .= $prop . ' = ?, ';
}
$i++; $i++;
} }
} }
} else {
// no table data was passed. Might be SELECT statement.
$this->_paramTypeList = $this->_determineType($where_value);
$this->_query .= " WHERE " . $where_prop . "= ?";
} }
//Prepair the where portion of the query
$this->_query .= ' WHERE ';
$i = 1;
foreach ($this->_where as $column => $value)
{
// Determines what data type the where column is, for binding purposes.
$this->_whereTypeList .= $this->_determineType($value);
// Prepares the reset of the SQL query.
($i === count($this->_where)) ?
$this->_query .= $column . ' = ?':
$this->_query .= $column . ' = ? AND ';
$i++;
}
} }
// Determine if is INSERT query // Determine if is INSERT query
if ($hasTableData && $this->_crudType == 'insert') { if ($hasTableData) {
$keys = array_keys($tableData); $pos = strpos($this->_query, 'INSERT');
$values = array_values($tableData);
$num = count($keys); if ($pos !== false) {
//is insert statement
// wrap values in quotes $keys = array_keys($tableData);
foreach ($values as $key => $val) { $values = array_values($tableData);
$values[$key] = "'{$val}'"; $num = count($keys);
$this->_paramTypeList .= $this->_determineType($val);
} // wrap values in quotes
foreach ($values as $key => $val) {
$values[$key] = "'{$val}'";
$this->_paramTypeList .= $this->_determineType($val);
}
$this->_query .= '(' . implode($keys, ', ') . ')'; $this->_query .= '(' . implode($keys, ', ') . ')';
$this->_query .= ' VALUES('; $this->_query .= ' VALUES(';
while ($num !== 0) { while ($num !== 0) {
($num !== 1) ? $this->_query .= '?, ' : $this->_query .= '?)'; ($num !== 1) ? $this->_query .= '?, ' : $this->_query .= '?)';
$num--; $num--;
}
} }
} }
...@@ -211,6 +269,7 @@ class MysqlDB { ...@@ -211,6 +269,7 @@ class MysqlDB {
if (isset($numRows)) { if (isset($numRows)) {
$this->_query .= " LIMIT " . (int) $numRows; $this->_query .= " LIMIT " . (int) $numRows;
} }
// Prepare query // Prepare query
$stmt = $this->_prepareQuery(); $stmt = $this->_prepareQuery();
...@@ -221,13 +280,21 @@ class MysqlDB { ...@@ -221,13 +280,21 @@ class MysqlDB {
foreach ($tableData as $prop => $val) { foreach ($tableData as $prop => $val) {
$args[] = &$tableData[$prop]; $args[] = &$tableData[$prop];
} }
call_user_func_array(array($stmt, 'bind_param'), $args); call_user_func_array(array($stmt, 'bind_param'), $args);
} else { } else {
if ($this->_where) if ($this->_where)
$stmt->bind_param($this->_paramTypeList, $where_value); {
$wheres = array();
$wheres[] = $this->_whereTypeList;
foreach ($this->_where as $prop => $val) {
$wheres[] = &$this->_where[$prop];
}
call_user_func_array(array($stmt, 'bind_param'), $wheres);
}
} }
// Clear where method to prevent clashes with future operations;
$this->_where = array();
return $stmt; return $stmt;
} }
...@@ -263,14 +330,13 @@ class MysqlDB { ...@@ -263,14 +330,13 @@ class MysqlDB {
/** /**
* Method attempts to prepare the SQL query * Method attempts to prepare the SQL query
* and throws an error if there was a problem. * and throws an error if there was a problem.
*/ */
protected function _prepareQuery() protected function _prepareQuery()
{ {
echo $this->_query; if (!$stmt = $this->_mysqli->prepare($this->_query)) {
if (!$stmt = $this->_mysql->prepare($this->_query)) { trigger_error("Problem preparing query ($this->_query) ".$this->_mysqli->error, E_USER_ERROR);
trigger_error("Problem preparing query", E_USER_ERROR);
} }
return $stmt; return $stmt;
} }
...@@ -278,7 +344,7 @@ class MysqlDB { ...@@ -278,7 +344,7 @@ class MysqlDB {
public function __destruct() public function __destruct()
{ {
$this->_mysql->close(); $this->_mysqli->close();
} }
} } // END class
\ No newline at end of file
<h3>Change Log</h3>
<p>Branch off master</p>
<ul>
<li>Changed package name to MySqliDb. This is a MySQLi wrapper.</li>
<li>Added support for multiple dynamicly bound where conditions.</li>
<li>Added state resetting after each query exicution to allow multiple calls to the same connection instance.</li>
<li>Added the ability to staticly retreive the current instance.</li>
<li>Added numRows support to the query method.</li>
<li>The triggered error in _prepareQuery() now also displays the SQL statment and the mysqli error message.</li>
</ul>
\ No newline at end of file
<?php <?php
require_once('MysqlDb.php'); require_once('MysqliDb.php');
$Db = new MysqlDb('localhost', 'root', 'root', 'db'); $db = new MysqliDb('localhost', 'root', 'root', 'db');
$insertData = array(
'title' => 'Inserted title',
'body' => 'Inserted body'
);
$results = $Db->insert('posts', $insertData);
print_r($results);
?> ?>
<!DOCTYPE html> <!DOCTYPE html>
...@@ -21,6 +12,16 @@ print_r($results); ...@@ -21,6 +12,16 @@ print_r($results);
<title>untitled</title> <title>untitled</title>
</head> </head>
<body> <body>
<?php
$insertData = array(
'title' => 'Inserted title',
'body' => 'Inserted body'
);
$results = $db->insert('posts', $insertData);
print_r($results);
?>
</body> </body>
</html> </html>
\ No newline at end of file
To utilize this class, first import MysqlDb.php into your project, and require it. To utilize this class, first import Mysqldbi.php into your project, and require it.
<pre> <pre>
<code> <code>
require_once('MysqlDb.php'); require_once('Mysqlidb.php');
</code> </code>
</pre> </pre>
...@@ -10,7 +10,7 @@ After that, create a new instance of the class. ...@@ -10,7 +10,7 @@ After that, create a new instance of the class.
<pre> <pre>
<code> <code>
$Db = new MysqlDb('host', 'username', 'password', 'databaseName'); $db = new Mysqlidb('host', 'username', 'password', 'databaseName');
</code> </code>
</pre> </pre>
...@@ -25,7 +25,7 @@ $insertData = array( ...@@ -25,7 +25,7 @@ $insertData = array(
'body' => 'Inserted body' 'body' => 'Inserted body'
); );
if ( $Db->insert('posts', $insertData) ) echo 'success!'; if ( $db->insert('posts', $insertData) ) echo 'success!';
</code> </code>
</pre> </pre>
...@@ -34,7 +34,7 @@ if ( $Db->insert('posts', $insertData) ) echo 'success!'; ...@@ -34,7 +34,7 @@ if ( $Db->insert('posts', $insertData) ) echo 'success!';
<pre> <pre>
<code> <code>
$results = $Db->get('tableName', 'numberOfRows-optional'); $results = $db->get('tableName', 'numberOfRows-optional');
print_r($results); // contains array of returned rows print_r($results); // contains array of returned rows
</code> </code>
</pre> </pre>
...@@ -47,8 +47,8 @@ $updateData = array( ...@@ -47,8 +47,8 @@ $updateData = array(
'fieldOne' => 'fieldValue', 'fieldOne' => 'fieldValue',
'fieldTwo' => 'fieldValue' 'fieldTwo' => 'fieldValue'
); );
$Db->where('id', int); $db->where('id', int);
$results = $Db->update('tableName', $updateData); $results = $db->update('tableName', $updateData);
</code> </code>
</pre> </pre>
...@@ -56,8 +56,8 @@ $results = $Db->update('tableName', $updateData); ...@@ -56,8 +56,8 @@ $results = $Db->update('tableName', $updateData);
<pre> <pre>
<code> <code>
$Db->where('id', integer); $db->where('id', int);
if ( $Db->delete('posts') ) echo 'successfully deleted'; if ( $db->delete('posts') ) echo 'successfully deleted';
</code> </code>
</pre> </pre>
...@@ -65,17 +65,18 @@ if ( $Db->delete('posts') ) echo 'successfully deleted'; ...@@ -65,17 +65,18 @@ if ( $Db->delete('posts') ) echo 'successfully deleted';
<pre> <pre>
<code> <code>
$results = $Db->query('SELECT * from posts'); $results = $db->query('SELECT * from posts');
print_r($results); // contains array of returned rows print_r($results); // contains array of returned rows
</code> </code>
</pre> </pre>
<h3> Where Method </h3> <h3> Where Method </h3>
<p>This method allows you to specify the parameters of the query. For now, it only accepts one key => value pair. </p> <p>This method allows you to specify the parameters of the query.</p>
<pre> <pre>
<code> <code>
$Db->where('id', int); $db->where('id', int);
$results = $Db->get('tableName'); $db->where('title', string);
$results = $db->get('tableName');
print_r($results); // contains array of returned rows print_r($results); // contains array of returned rows
</code> </code>
</pre> </pre>
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