mysql更新语句用法_MySQL update 语句的正确用法
以下的文章主要介绍的MySQL
update 语句的实际用法,我们首先是以单表的UPDATE语句来引出实现MySQL update 语句的实际方案,以下就是文章的详细内容描述,望你看完之后会有收获。
单表的MySQL UPDATE语句:
UPDATE [LOW_PRIORITY] [IGNORE] tbl_name
SET
col_name1
=
expr1
[,
col_name2
=
expr2
...]
[WHERE where_definition]
[ORDER BY ...]
[LIMIT row_count]
多表的UPDATE语句:
UPDATE [LOW_PRIORITY] [IGNORE] table_references
SET
col_name1
=
expr1
[,
col_name2
=
expr2
...]
[WHERE where_definition]
UPDATE语法可以用新值更新原有表行中的各列。SET子句指示要修改哪些列和要给予哪些值。WHERE子句指定应更新哪些行。如果没有
WHERE子句,则更新所有的行。如果指定了ORDER
BY子句,则按照被指定的顺序对行进行更新。LIMIT子句用于给定一个限值,限制可以被更新的行的数目。
MySQL UPDATE语句支持以下修饰符:
如果您使用LOW_PRIORITY关键词,则UPDATE的执行被延迟了,直到没有其它的客户端从表中读取为止。
如果您使用IGNORE关键词,则即使在更新过程中出现错误,更新语句也不会中断。如果出现了重复关键字冲突,则这些行不会被更新。如果列被更新后,新值会导致数据转化错误,则这些行被更新为最接近的合法的值。
如果您在一个表达式中通过tbl_name访问一列,则UPDATE使用列中的当前值。例如,以下语句把年龄列设置为比当前值多一:
MySQL>
UPDATE persondata SET
age
age
=age+1;
MySQL UPDATE赋值被从左到右评估。例如,以下语句对年龄列加倍,然后再进行增加:
MySQL>
UPDATE persondata SET
age
age
=age*2,
age
age
=age+1;
如果您把一列设置为其当前含有的值,则MySQL会注意到这一点,但不会更新。
如果您把被已定义为NOT NULL的列更新为NULL,则该列被设置到与列类型对应的默认值,并且累加警告数。对于数字类型,默认值为0;对于字符串类型,默认值为空字符串('');对于日期和时间类型,默认值为“zero”值。
UPDATE会返回实际被改变的行的数目。MySQL_info() C API函数可以返回被匹配和被更新的行的数目,以及在UPDATE过程中产生的警告的数量。
您可以使用LIMIT row_count来限定UPDATE的范围。LIMIT子句是一个与行匹配的限定。只要发现可以满足WHERE子句的row_count行,则该语句中止,不论这些行是否被改变。
如果一个UPDATE语句包括一个ORDER BY子句,则按照由子句指定的顺序更新行。
您也可以执行包括多个表的UPDATE操作。table_references子句列出了在联合中包含的表。以下是一个例子:
SQL
>
UPDATE items,month
SET
items.price
=
month
.price
WHERE
items.id
=
month
.id;
以上的例子显示出了使用逗号操作符的内部联合,但是multiple-table UPDATE语句可以使用在SELECT语句中允许的任何类型的联合,比如LEFT JOIN。
注释:您不能把ORDER BY或LIMIT与multiple-table UPDATE同时使用。
在一个被更改的multiple-table UPDATE中,有些列被引用。您只需要这些列的MySQL UPDATE权限。有些列被读取了,但是没被修改。您只需要这些列的SELECT权限。
如果您使用的multiple-table
UPDATE语句中包含带有外键限制的InnoDB表,则MySQL优化符处理表的顺序可能与上下层级关系的顺序不同。在此情况下,语句无效并被
回滚。同时,更新一个单一表,并且依靠ON UPDATE功能。该功能由InnoDB提供,用于对其它表进行相应的修改。
目前,您不能在一个子查询中更新一个表,同时从同一个表中选择。
原文链接:http://database.51cto.com/art/201005/201953.htm
分享到:
2013-01-06 18:48
浏览 1366
分类:数据库
评论
mysql更新语句用法_MySQL update 语句的正确用法相关推荐
- mysql的更新用法_mysql update语句的用法详解
本节内容: mysql数据库中的update语句. 首先,单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr ...
- mysql update用法_mysql update语句的用法详解
首先,单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 ...] ...
- mysql更新代码_mysql update语句的用法
1. 单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 .. ...
- mysql更新多字段sql_SQL UPDATE 更新语句用法(单列与多列)
Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称SET列名称 = 新值 WHERE 列名称 = 某值 例如: Person表: LastName FirstNa ...
- mysql update 有中文_MySQL Update语句一个非常经典的“坑”
点击关注上方"SQL数据库开发", 设为"置顶或星标",第一时间送达干货 起因 最近好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面 ...
- delete语句与reference约束冲突怎么解决_mysql update语句和原数据一样会更新么
戳蓝字「TopCoder」关注我们哦! 平常使用 mysql ,必不可少的会用到 update 语句,不知道小伙伴有没有这样的疑问? 如果 update 语句和原数据一样会更新么?更具体的来说,如果 ...
- mysql PREPARE用法_mysql prepare语句使用
每次都看别人的,今天我自己写下来,以后就不用看别人的了 语法 PREPARE statement_name FROM sql_text /*定义*/ EXECUTE statement_name [U ...
- php update语句,php中update语句用法介绍
php中update语句用法介绍 发布时间:2020-06-12 16:40:44 来源:亿速云 阅读:175 作者:小新 本篇文章和大家了解一下php中update语句用法介绍.有一定的参考价值,有 ...
- mysql更新多条数据6_mysql语句:批量更新多条记录的不同值
mysql更新语句很简单,更新一条数据的某个字段,一般这样写: 如果更新同一字段为同一个值,mysql也很简单,修改下where即可: 这里注意 'other_values' 是一个逗号(,)分隔的字 ...
最新文章
- WISMO模块GPRS上网设置的过程
- Nacos真香,从零到一学起来
- tomcat源码研究
- mysql数据库约束无符号,MySQL所支持的数据类型与表字段约束类型的学习教程
- OpenCV cv :: UMat与DirectX9ex曲面的互操作性的实例(附完整代码)
- 腾讯数据库内核团队资深架构师:TXSQL Internals @2018
- sql 临时表_原创 | SQL优化之合理使用临时表
- Soul回应赴美上市传闻:不是约会软件 没有确定的上市计划
- java 拷贝大文件_java高效实现大文件拷贝功能
- docker兼容的linux内核,CentOS 6.5上安装Docker与Docker对中文字符集的支持
- Linux环境下配置JDK,java环境
- Java 面试——字符串操作、值传递、重载与重写
- user reg.php,织梦member/reg_new.php SQL注入漏洞修复
- 期末速通主成分分析(PCA)
- HTML5网页多媒体( 音频,视频,旧版本浏览器提示,格式兼容,多媒体标签属性)
- 常见排序算法原理及java实现
- stm32f407的串口通信传输不了且串口调试软件无法显示的问题
- 计算机考研用python_本科化工考研跨考计算机,学过高数和Python,难度有多大?...
- 几种修复照片画质的方法
- php倒序正序,php foreach正序倒序输出示例代码
热门文章
- 搜索引擎的收录——百度
- C++获取CPU核心数(用来初始化线程池)
- 有关联想昭阳本本的拆装
- 代码忍者通过CoderDojo获得“腰带”
- 远程管理协议与远程工具
- mac设置mysql root密码_mac如何更改mysql root密码 Mac平台重新设置MySQL的root密码
- Unable to start embedded container和Consider defining a bean:SpringBoot搭建多模块项目错误
- Winrar发现损坏的压缩文件头
- ubuntu 装kali tools
- 【AutoCAD】AutoCAD命令