doujing6436 2017-12-24 12:10
浏览 55
已采纳

PHP mysqli准备语句自己的类

I want to write a method for adding records to the database.

My method:

final public function newData($sql, $placeholder, $array) {
  $stmt = $this->db->prepare($sql);
  $stmt->bind_param($placeholder, implode(",", $array));
  return $stmt->execute();
}

..................

// Code---Example
$sql = "INSERT INTO table (name, data) VALUES (?,?)";

$placeholder =  "ss";

final public function newData($sql, $placeholder, [$array]) {
  $stmt = $this->db->prepare($sql);
  $stmt->bind_param($placeholder, implode(",", $array));
  return $stmt->execute();
 }

My problem is if I want to save several values with this method. I get a warning

Warning: mysqli_stmt:: bind_param (): Number of elements in type definition string doesn't match number of bind variables in ##

What am I doing wrong?

  • 写回答

1条回答 默认 最新

  • dreamy1992 2017-12-24 12:22
    关注

    You can't use $stmt->bind_param() that way. You would need to do argument unpacking because bind_param requires type and then each value as an argument.

    final public function newData($sql, $placeholder, $array) {
        $stmt = $this->db->prepare($sql);
        $stmt->bind_param($placeholder, ...$array);
        return $stmt->execute();
    }
    

    Then use like:

    $sql = "INSERT INTO table (name, data) VALUES (?,?)";
    
    $result = $theDbClass->newData($sql, 'ss', ['foo', 'bar']);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?