MySQL增删改查之改_update

UPDATE语句  

  进行数据记录的更新。

1、更新单个表中的值

语法:

UPDATE   [IGNORE]  table_reference
  SET col_name1=expr1 [, col_name2=expr2,],...
  [WHERE where_condition]
  [ORDER BY ...]
  [LIMIT row_count]

①有where子句的,将满足WHERE条件的所有行的一个或多个列值改为新的值;

②没有WHERE子句,则会对该表中所有的记录的指定的列的所有行,进行修改更新操作。

基本格式:

  update <表名> set <列名>=<值或值的表达式>  where <条件表达式>;

例1:把95号球员的联盟会员号码改为2000(值)

UPDATE  players

  SET  leagueno = 2000

  WHERE playerno = 95;

例2: 把所有的罚款增加5%(值的表达式)

UPDATE penalties

  SET amount = amount*1.05;

例3: 把住在Stratford的球员的获胜局数设为0(指定列所有行)

UPDATE matches

  SET won = 0

  WHERE playerno IN

  (SELECT playerno FROM players WHERE town='Stratford');

注意:在SET子句的子查询中,不允许访问要更新的表。

UPDATE <表1>

  SET amount = amount-(SELECT avg(amount) FROM 表1);

!!上述写法不允许

解决(分两步):

mysql> SET @avg_amount = (SELECT avg(amount) FROM <表1>);

mysql> UPDATE <表1>

SET amount = amount - @avg_amount;


UPDATE语句中的ORDER BY子句

  UPDATE语句中可以使用ORDER BY子句,要求以排序的顺序来依次更新行。

在某些场景可能有用,例如:想要把所有罚款的罚款编号都加1

  ①如果从罚款编号为1的行开始更新,要么就会发生主键值重复异常;

  ②如果从罚款编号最大的行开始更新,就没有问题。

示例:把所有罚款的编号增加1

UPDATE  penalties

  SET  paymentno = paymentno + 1

  ORDER BY  paymentno DESC;


UPDATE语句中的LIMIT子句

  UPDATE语句中可以使用LIMIT子句,指定一次更新的行数

示例:把4个最高的罚款额增加5%(罚款额相同则更新编号小的球员)

UPDATE  penalties

  SET  amount= amount *1.05

  ORDER BY  amount DESC, playerno ASC

  LIMIT 4;

2、更新多个表中的值

优点:要么两个表都更新,要么两个表都不更新

语法:

UPDATE   [IGNORE]  table_references
SET col_name1=expr1 [, col_name2=expr2,],...
[WHERE where_condition]

基本格式:

  update <表名> set <列名1>=<值或值的表达式>, <列名2>=<值或值的表达式> ... where <条件表达式> ;

注意:

  ①table_references可以使用任何合法的连接语法

  ②不能使用ORDER BY和LIMIT子句

示例:把一个first分级球队的所有比赛的获胜局数设为0,并把first分级球队的队长编号改为112

UPDATE matches m,teams t

  SET m.won = 0,t.playerno = 112

WHERE t.teamno = m.teamno

AND t.division = 'first';

解析:首先执行一个二表连接查询,从两个表中找到满足连接条件 t.teamno = m.teamno 的所有行,然后对这些行分别进行更新。

MySQL之改_update的更多相关文章

  1. MySQL数据库改名字

    在这里首先感谢那个网上已经给出了解决办法的同志 有很多MySQL数据库的初学者可能都会遇到一个关于改名字的问题,可能大家第一时间就会想到去网上搜搜,其实我跟大家的心理是一样的(呵呵). 据我所知,My ...

  2. python mysql增加改查

    #python mysql增加改查,方便日后copy/paste .......... 1 #encoding: UTF-8 2 import pymysql 3 # # 打开数据库连接 4 db = ...

  3. 将现有MySQL数据库改为大小写不敏感

    用过MySQL的应该都会注意到,默认情况下,Linux下安装的MySQL是大小写敏感的,也就是说Table1和table1可以同时存在.而Windows下的MySQL却是大小写不敏感的,所有表名和数据 ...

  4. mysql utf8改utf8mb4

    由于需要用到utf8mb4,之前是utf8现在给改成utf8mb4 查看当前环境 SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' ...

  5. MySQL更新命令_UPDATE

    创建测试表 mysql> CREATE TABLE `product` ( -> `proID` ) NOT NULL AUTO_INCREMENT COMMENT '商品表主键', -& ...

  6. MySQL Replication--修改主键为NULL导致的异常

    测试环境:MySQL 5.5.14/MySQL 5.6.36 测试脚本: create table tb001(id int primary key,c1 int); alter table tb00 ...

  7. 【备份】使用mysqldump 实现rename database name(mysql数据库改名称)

    需求:将jxl_credit改名为jxl_test;输入:jxl_credit输出: jxl_test; 实现方式:1).新建jxl_test,2).备份jxl_credit到本地,3).然后将备份数 ...

  8. mysql查改

    1 MySQL UNION 操作符语法格式: SELECT expression1, expression2, ... expression_n FROM tables [WHERE conditio ...

  9. mysql在线改表结构 pt-online-schema-change

    https://www.percona.com/doc/percona-toolkit/2.1/pt-online-schema-change.html 不锁表更改数据库表结构 pt-online-s ...

随机推荐

  1. 1935: [Shoi2007]Tree 园丁的烦恼

    1935: [Shoi2007]Tree 园丁的烦恼 Time Limit: 15 Sec  Memory Limit: 357 MBSubmit: 648  Solved: 273[Submit][ ...

  2. Servlet中的过滤器Filter详解

    加载执行顺序 context-param->listener->filter->servlet web.xml中元素执行的顺序listener->filter->stru ...

  3. Android中的WebView实战详解(一)

    一.为什么要用WebView? 1.兼容已有的项目2.可动态更新 二.WebView怎样使用? WebView是一个控件,如在布局中设置: <WebView android:id="@ ...

  4. PHP数据访问易错点(20161030)

    易错点: 1.造对象的时候括号里面的参数 写错了 $db = new MySQLi("localhost","root","789",&qu ...

  5. MySQL查询语句的45道练习

              一.设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表(四) ...

  6. 【Python系列】Python自动发邮件脚本-html邮件内容

    缘起 这段时间给朋友搞了个群发邮件的脚本,为了防止进入垃圾邮件,做了很多工作,刚搞完,垃圾邮件进入率50%,觉得还不错,如果要将垃圾邮件的进入率再调低,估计就要花钱买主机了,想想也就算了,先发一个月, ...

  7. 配置uwsgi

    首先要明确的是,如果你喜欢用命令行的方式(如shell)敲命令,那可以省去任何配置. 但是,绝大多数人,还是不愿意记那么长的命令,反复敲的.所以uwsgi里,就给大家提供了多种配置,省去你启动时候,需 ...

  8. webkit图片滤镜

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  9. Python 一些有趣的技巧哦!

    #Python 技巧命令 python 如一股清流,可以说屌到飞起,下面咱就来看看一些屌的东西 ### python2 最简单的web服务 ` python -m SimpleHTTPServer 8 ...

  10. Nginx网站使用CDN之后禁止用户真实IP访问的方法

    做过面向公网WEB的运维人员经常会遇见恶意扫描.拉取.注入等图谋不轨的行为,对于直接对外的WEB服务器,我们可以直接通过 iptables .Nginx 的deny指令或是程序来ban掉这些恶意请求. ...