以下的文章主要介绍的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 语句的正确用法相关推荐

  1. mysql的更新用法_mysql update语句的用法详解

    本节内容: mysql数据库中的update语句. 首先,单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr ...

  2. mysql update用法_mysql update语句的用法详解

    首先,单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 ...] ...

  3. mysql更新代码_mysql update语句的用法

    1.    单表的UPDATE语句: UPDATE [LOW_PRIORITY] [IGNORE] tbl_name SET col_name1=expr1 [, col_name2=expr2 .. ...

  4. mysql更新多字段sql_SQL UPDATE 更新语句用法(单列与多列)

    Update 语句 Update 语句用于修改表中的数据. 语法: UPDATE 表名称SET列名称 = 新值 WHERE 列名称 = 某值 例如: Person表: LastName FirstNa ...

  5. mysql update 有中文_MySQL Update语句一个非常经典的“坑”

    点击关注上方"SQL数据库开发", 设为"置顶或星标",第一时间送达干货 起因 最近好几次有开发同学在钉钉上问我,比如下图: 问题归纳起来就是:在MySQL里面 ...

  6. delete语句与reference约束冲突怎么解决_mysql update语句和原数据一样会更新么

     戳蓝字「TopCoder」关注我们哦! 平常使用 mysql ,必不可少的会用到 update 语句,不知道小伙伴有没有这样的疑问? 如果 update 语句和原数据一样会更新么?更具体的来说,如果 ...

  7. mysql PREPARE用法_mysql prepare语句使用

    每次都看别人的,今天我自己写下来,以后就不用看别人的了 语法 PREPARE statement_name FROM sql_text /*定义*/ EXECUTE statement_name [U ...

  8. php update语句,php中update语句用法介绍

    php中update语句用法介绍 发布时间:2020-06-12 16:40:44 来源:亿速云 阅读:175 作者:小新 本篇文章和大家了解一下php中update语句用法介绍.有一定的参考价值,有 ...

  9. mysql更新多条数据6_mysql语句:批量更新多条记录的不同值

    mysql更新语句很简单,更新一条数据的某个字段,一般这样写: 如果更新同一字段为同一个值,mysql也很简单,修改下where即可: 这里注意 'other_values' 是一个逗号(,)分隔的字 ...

最新文章

  1. WISMO模块GPRS上网设置的过程
  2. Nacos真香,从零到一学起来
  3. tomcat源码研究
  4. mysql数据库约束无符号,MySQL所支持的数据类型与表字段约束类型的学习教程
  5. OpenCV cv :: UMat与DirectX9ex曲面的互操作性的实例(附完整代码)
  6. 腾讯数据库内核团队资深架构师:TXSQL Internals @2018
  7. sql 临时表_原创 | SQL优化之合理使用临时表
  8. Soul回应赴美上市传闻:不是约会软件 没有确定的上市计划
  9. java 拷贝大文件_java高效实现大文件拷贝功能
  10. docker兼容的linux内核,CentOS 6.5上安装Docker与Docker对中文字符集的支持
  11. Linux环境下配置JDK,java环境
  12. Java 面试——字符串操作、值传递、重载与重写
  13. user reg.php,织梦member/reg_new.php SQL注入漏洞修复
  14. 期末速通主成分分析(PCA)
  15. HTML5网页多媒体( 音频,视频,旧版本浏览器提示,格式兼容,多媒体标签属性)
  16. 常见排序算法原理及java实现
  17. stm32f407的串口通信传输不了且串口调试软件无法显示的问题
  18. 计算机考研用python_本科化工考研跨考计算机,学过高数和Python,难度有多大?...
  19. 几种修复照片画质的方法
  20. php倒序正序,php foreach正序倒序输出示例代码

热门文章

  1. 搜索引擎的收录——百度
  2. C++获取CPU核心数(用来初始化线程池)
  3. 有关联想昭阳本本的拆装
  4. 代码忍者通过CoderDojo获得“腰带”
  5. 远程管理协议与远程工具
  6. mac设置mysql root密码_mac如何更改mysql root密码 Mac平台重新设置MySQL的root密码
  7. Unable to start embedded container和Consider defining a bean:SpringBoot搭建多模块项目错误
  8. Winrar发现损坏的压缩文件头
  9. ubuntu 装kali tools
  10. 【AutoCAD】AutoCAD命令