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 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀