Browse Source

Fixed bug in bindings that was causing null to be saved as 0 in MySQL.

Taylor Otwell 13 years ago
parent
commit
514c128957
1 changed files with 15 additions and 1 deletions
  1. 15 1
      system/db.php

+ 15 - 1
system/db.php

@@ -52,7 +52,21 @@ class DB {
 	{
 		$query = static::connection($connection)->prepare($sql);
 
-		$result = $query->execute($bindings);
+		$bindings = array_values($bindings);
+
+		foreach ($bindings as $key => &$binding)
+		{
+			if (is_null($binding))
+			{
+				$query->bindValue($key + 1, null, \PDO::PARAM_INT);
+			}
+			else
+			{
+				$query->bindParam($key + 1, $binding);
+			}
+		}
+
+		$result = $query->execute();
 
 		if (strpos(strtoupper($sql), 'SELECT') === 0)
 		{