0

0

php怎么更新数据_UPDATE语句修改指定记录的操作【汇总】

雪夜

雪夜

发布时间:2025-12-29 19:10:03

|

233人浏览过

|

来源于php中文网

原创

PHP执行UPDATE需用mysqli或PDO预处理语句,必须带WHERE条件,通过affected_rows或rowCount检查实际影响行数,并注意字符集、SQL模式与事务提交。

php怎么更新数据_update语句修改指定记录的操作【汇总】

PHP 中执行 UPDATE 语句的基本写法

PHP 本身不直接“更新数据”,而是通过数据库扩展(如 mysqliPDO)向 MySQL 等数据库发送 UPDATE SQL 语句。最安全、推荐的方式是使用预处理语句,避免 SQL 注入。

关键点:必须带 WHERE 条件,否则整张表所有记录都会被修改。

  • mysqli 面向对象风格示例:
$mysqli = new mysqli("localhost", "user", "pass", "db");
$stmt = $mysqli->prepare("UPDATE users SET name = ?, email = ? WHERE id = ?");
$stmt->bind_param("ssi", $new_name, $new_email, $id);
$new_name = "Alice";
$new_email = "alice@example.com";
$id = 123;
$stmt->execute();
  • PDO 预处理示例:
$pdo = new PDO("mysql:host=localhost;dbname=db", "user", "pass");
$stmt = $pdo->prepare("UPDATE users SET status = :status WHERE id = :id");
$stmt->execute(["status" => "active", "id" => 456]);

为什么不能直接拼接字符串执行 UPDATE

"UPDATE users SET name = '" . $_POST['name'] . "' WHERE id = " . $_GET['id'] 这类拼接方式极危险。一旦用户输入包含单引号或 SQL 片段(如 ' OR 1=1 -- ),就可能触发全表更新、删库甚至拖库。

  • 常见错误现象:mysqli_query() 返回 true,但实际改了 0 行或全部行,日志里查不到明确报错
  • mysql_* 函数已彻底废弃(PHP 7.0+ 移除),不能再用
  • 即使加了 mysqli_real_escape_string(),也无法完全防御多字节编码绕过或边界场景

UPDATE 执行后怎么确认是否成功修改了数据

不能只看 execute()query() 是否返回 true——它只表示 SQL 语法正确、连接正常,并不反映是否有匹配记录被更新。

立即学习PHP免费学习笔记(深入)”;

蛙蛙写作
蛙蛙写作

超级AI智能写作助手

下载
  • mysqli_stmt::affected_rows 返回实际被修改的行数(注意:若新旧值相同,MySQL 默认返回 0)
  • PDOStatement::rowCount() 同理,返回匹配并变更的行数
  • 需要结合业务逻辑判断:比如期望改 1 行,结果 rowCount() === 0,可能是 WHERE 条件没命中,也可能是原值本就一样

示例检查逻辑:

$stmt->execute();
if ($stmt->rowCount() === 0) {
    echo "未找到匹配的记录,或数据未发生实际变更";
}

UPDATE 操作中容易忽略的细节

很多问题不是语法错,而是隐含行为导致的“看似没更新”:

  • MySQL 的 sql_mode 包含 STRICT_TRANS_TABLES 时,对空字符串插入非空字段会报错;不启用时可能静默截断或转为默认值
  • 时间字段(如 DATETIME)传入非法格式("2024-02-30")在宽松模式下会变成 "0000-00-00",但不会报错
  • 字符集不一致:PHP 文件是 UTF-8,但数据库连接未设 SET NAMES utf8mb4,中文可能存成乱码或被截断
  • 事务未提交:PDO 默认自动提交,但若手动调用了 beginTransaction(),忘记 commit() 就等于没改

建议在连接建立后立即设置:

$mysqli->set_charset("utf8mb4");
// 或 PDO DSN 加上 charset:
$pdo = new PDO("mysql:host=localhost;dbname=db;charset=utf8mb4", ...);

UPDATE 不是黑盒操作,每一步的返回值、影响行数、字符集和 SQL 模式都得盯住。尤其上线前用真实数据测一遍 WHERE 条件是否精准命中目标记录。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1840

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1221

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1113

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1398

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1229

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 776人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号