У меня есть класс подключения DB, все в порядке, за исключением шага при привязке значений, он вставляет последние данные поля во все поля плюс тип, а привязка возвращает число 2, а не (INT, BOOL, NULL, ...), как я указал:DB connect class: bind issue
Таким образом, он должен вставить:
налить fied1 в field1 залить fied2 в field2 залить fied3 в field3
и так далее, вот код:
<?php
final class crud {
public function __construct($connexionName) {
$this->connexionName = $connexionName;
}
public final function insert($tableName, $fields=array()){
$this->tableName = $tableName;
$this->fields = $fields;
foreach ($this->fields as $vf) {
$inKeys[] = $vf;
$inKeysDotted[] = ':' . $vf;
$insImKeys = implode(', ', $inKeys);
$insImKeysDotted = implode(', ', $inKeysDotted);
$this->insImKeys = $insImKeys;
$this->insImKeysDotted = $insImKeysDotted;
}
$this->insertedKeys = $inKeys;
$this->insertedKeysDotted = $inKeysDotted;
//print_r($this->insertedKeys);
//echo '<br />';
$sql = "INSERT INTO `$this->tableName` ($this->insImKeys) VALUES ($this->insImKeysDotted);";
//echo $sql.'<br />';
$insertItems = $this->connexionName->prepare($sql);
$this->insertItems = $insertItems;
//print_r($insertItems).'<br />';
} // end prepareStm()
public final function bindParams($setValues=array()){
$combine = array_combine($this->insertedKeys, $setValues);
foreach ($combine as $getKey => $getVal) {
switch ($getVal) {
case is_int($getVal):
//echo $getVal .' is INT<br />';
$setType = PDO::PARAM_INT;
//return PDO::PARAM_INT;
break;
case is_bool($getVal):
//echo $getVal .' is BOOL<br />';
$setType = PDO::PARAM_BOOL;
//return PDO::PARAM_BOOL;
break;
case is_null($getVal):
//echo $getVal .' is NULL<br />';
$setType = PDO::PARAM_NULL;
//return PDO::PARAM_NULL;
break;
default:
//echo $getVal .' is STR<br />';
$setType = PDO::PARAM_STR;
//return PDO::PARAM_STR;
break;
return $setType;
}
echo "this->insertItems->bindParam($getKey, $getVal, $setType)<br />";
$this->insertItems->bindParam($getKey, $getVal, $setType);
//echo '<pre>';
//print_r($this->insertItems);
//echo '</pre>';
}
} // end bindParams()
public final function executeQuery(){
return $this->insertItems->execute();
}
}
require_once '../Included_Files/Connect.php';
$con = new crud($connexion);
echo '<br />';
$con->insert('test', array('field1', 'field2', 'field3'));
$con->bindParams(array('pour field1', 'pour field2', 'pour field3'));
$con->executeQuery();
?>
Результат эхо и print_r являются:
INSERT INTO `test` (field1, field2, field3) VALUES (:field1, :field2, :field3);
this->insertItems->bindParam(field1, pour field1, 2)
this->insertItems->bindParam(field2, pour field2, 2)
this->insertItems->bindParam(field3, pour field3, 2)
Спасибо за вашу поддержку
Я использовал, если/else, все равно останется тем же результатом: 'if (is_int ($ getVal)) {$ setType = PDO :: PARAM_INT; } ' –
Но вы изменили' bindParam() 'на' bindValue() '? Это основная проблема в вашем коде, которая мешает ему вообще работать. – jbafford
Да, я сделал, я отлично смотрю –