PHP MySql update() 带数组

标签 php mysql

我想借助数组更新我的数据库,如何编写代码才正确?

这是我的代码,但它给出了有关 MySql 服务器版本的错误。

 public function update($fields, $values, $id) {
        $implodeFieldsArray = implode( ',', $fields );
        $implodeValuesArray = '"'.implode( '","', $values ).'"';
        $stmt = $this->conn->prepare('UPDATE $this->tabname ('.$implodeFieldsArray.') WHERE id=$id VALUES ('.$implodeValuesArray.')');
        $stmt->execute();
    }

最佳答案

根据 mysql 文档,这是正确的语法:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference
SET col_name1={expr1|DEFAULT} [, col_name2={expr2|DEFAULT}] ...
[WHERE where_condition]
[ORDER BY ...]
[LIMIT row_count]

您的代码将变为:

public function update($fields, $values, $id) {
    $update = "";
    $update = "";
    for ($i=0;$i<count($fields)-1;$i++){
      $update .= $fields[$i]."='".$values[$i]."',";
    }
    $update .= $fields[$i]."='".$values[$i]."'";
    $sql = 'UPDATE '.$this->tabname.' SET '.$update.' WHERE id='.$id;
    $stmt = $this->conn->prepare($sql);
    $stmt->execute();
}

关于PHP MySql update() 带数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40070082/

相关文章:

php - 如何按相关性对MYSQL全文搜索结果进行排序

mysql - 优化sql join查询,对比查询效果

php - DOMDocument/Xpath-如何从表中获取特定行

javascript - 如何使用ajax重新加载图像

php - Codeigniter 2.0 中是否可以使用析构函数?

php - Codeigniter 数据表查询不起作用?

Mysql 存储和检索时间和日期

php - 从下拉列表中选择,然后可以在以后的 WHERE 中使用?

mysql - MySQL 中何时使用单引号、双引号和反引号

php - Laravel 5.0 utf8 转换?