SQL基础语法—update语句

1 update语句介绍

update语句用来修改表中的数据内容

Single-table syntax:

UPDATE [LOW_PRIORITY] [IGNORE] table_reference
    SET assignment_list
    [WHERE where_condition]
    [ORDER BY ...]
    [LIMIT row_count]

Multiple-table syntax:

UPDATE [LOW_PRIORITY] [IGNORE] table_references
    SET assignment_list
    [WHERE where_condition]

update语句的常规用法

update students set sname='abcd',gender='1' where sid=1;
update student,students set students.sname=student2.sname,students.gender=students2.gender where students.sid=students2.sid;
  • 单表修改是指修改指定单个表中的已经存在数据的一个或多个列的数据; set 短语后面跟要修改的列和值
  • where 子句表示限定要修改表中的哪些行数据,如果没有where子句则表示所有行都要修改; order by 子句表示 update 数据按照指定的顺序进行; limit 子句表示限定修改数据的行数
  • 多表修改是指修改 table_references 指定的多个表中满足条件的行数据,多表修改不允许使用 order bylimit 子句
  • 执行 update 语句需要修改表的权限
  • low_priority 关键词表示修改语句需要等待其他链接的读此表操作结束后再执行,之作用在 MylSAMMEMORYMERGE 存储引擎
  • ignore 关键词表示当前修改语句碰到违反唯一性约束条件等情况时,语句不会报错回退而是报警告信息

2 update语句使用示例

2.1 单表修改

##修改全表中的数据,慎用
mysql> update student2 set sname='aaa';

##加上where限制条件,修改指定行的数据
mysql> update student2 set sname='aaa' where sid=1006;

##sid字段比原值增加1,哪一行先执行时随机的
mysql> update student2 set sid=1+sid;

##将sid字段设置成primary key,会出先以下错误,原因是,哪一行数据的sid先+1是随机的
mysql> update student2 set sid=1+sid;
ERROR 1062 (23000): Duplicate entry '1005' for key 'PRIMARY'

##所以在使用update时,一般会结合order by子句对数据先进行排序
mysql> update student2 set sid=sid+1 order by sid desc;  ##默认是升序,desc表示降序
Query OK, 2 rows affected (0.06 sec)
Rows matched: 2  Changed: 2  Warnings: 0

##使用limit限定行数,一般和order by配合使用
mysql> update student2 set sname='sss' order by id limit 2;

2.2 多表修改

##多表修改(表之间通过where条件进行join操作)
mysql> update items,month set items.price=month.price where items.id=month.id;

案例演示:

##案例需求:使用一条命令将students表中a,b改成students2中的aa,bb
mysql> select * from students;
+-----+-------+--------+---------+
| sid | sname | gender | dept_id |
+-----+-------+--------+---------+
|   1 | a     |      1 |       1 |
|   4 | b     |      1 |       1 |
+-----+-------+--------+---------+
2 rows in set (0.00 sec)

mysql> select * from students2;
+-----+-------+--------+---------+
| sid | sname | gender | dept_id |
+-----+-------+--------+---------+
|   1 | aa    |      1 |       1 |
|   3 | bb    |      1 |       1 |
|   4 | cc    |      1 |       1 |
+-----+-------+--------+---------+
3 rows in set (0.00 sec)
mysql> mysql> update students,students2 set students.sname=students2.sname where students.sid=students2.sid;

3 回滚机制简单设置

MySQL中的 autocommit 参数控制着是否可以回滚,默认其实开启的,开启代表自动回滚,使用 set autocommit=off 开启手动回滚功能,使用 rollback 命令,就可做回滚操作。

rollback 回滚机制:当执行 commitrollback 命令,表示当前事务的结束,下一个事务开始:

  • commit :终止当前的事物,该命令执行后, rollback 不能返回到上个事务的初始状态
  • rollback :回滚当前的操作到此前事务的初始状态

4 练习

  • 将所有学号小于等于100的学生的系改为 education
mysql> update students set students.dept_id=(select id from dept where dept_name='education');

mysql> update students,dept set students.dept_id=dept.id where sid<=100 and dept_name='education';
  • 将姓名为 ruthid 在100和200之间的老师的姓名改成 carey
mysql> update teacher set teacher.name='carey' where teacher.name='ruth' and id>100 and id<200;
我来评几句
登录后评论

已发表评论数()

相关站点

热门文章