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']);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序