Có, bindParam
liên kết một tham số với một tên biến (tham chiếu), không phải giá trị, như hướng dẫn sử dụng cho biết
.
Tuy nhiên, có một cú pháp đơn giản hơn cho tình huống của bạn. PDOStatement::execute
có thể nhận một mảng giá trị.
public function insert($table, $cols, $values){
$placeholder = array();
for ($i = 0; i < count($values); $i++)
$placeholder[] = '?';
$sql = 'INSERT INTO '. $table . ' (`' . implode("`, `", $cols) . '`) ';
$sql.= 'VALUES (' . implode(", ", $placeholder) . ')';
$stmt = $this->dbh->prepare($sql);
$stmt->execute($values);
}