MySQL更新命令_UPDATE
创建测试表
mysql> CREATE TABLE `product` (
-> `proID` int() NOT NULL AUTO_INCREMENT COMMENT '商品表主键',
-> `price` decimal(,) NOT NULL COMMENT '商品价格',
-> `type` int() NOT NULL COMMENT '商品类别(0生鲜,1食品,2生活)',
-> `dtime` datetime NOT NULL COMMENT '创建时间',
-> PRIMARY KEY (`proID`)
-> ) ENGINE=InnoDB AUTO_INCREMENT= DEFAULT CHARSET=utf8 COMMENT='商品表';
Query OK, rows affected (0.11 sec) mysql> CREATE TABLE `producttype` (
-> `ID` int() NOT NULL COMMENT '商品类别(0生鲜,1食品,2生活)',
-> `amount` int() COMMENT '每种类别商品总金额',
-> UNIQUE KEY (`ID`)
-> ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商品类别资金汇总表'
-> ;
Query OK, rows affected (0.12 sec)
mysql> INSERT INTO product(price,type,dtime) VALUES(10.00,0,now()),(10.00,1,now()),(10.00,1,now()),(20.00,2,now()),(30.00,3,now());
Query OK, 5 rows affected (0.06 sec)
Records: 5 Duplicates: 0 Warnings: 0
mysql> INSERT INTO producttype(ID) VALUES(1),(2),(3);
Query OK, 3 rows affected (0.04 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql> select * from product;
+-------+-------+------+---------------------+
| proID | price | type | dtime |
+-------+-------+------+---------------------+
| | 10.00 | | -- :: |
| | 10.00 | | -- :: |
| | 10.00 | | -- :: |
| | 20.00 | | -- :: |
| | 30.00 | | -- :: |
+-------+-------+------+---------------------+
rows in set (0.00 sec) mysql> select * from producttype;
+----+--------+
| ID | amount |
+----+--------+
| | NULL |
| | NULL |
| | NULL |
+----+--------+
rows in set (0.00 sec)
1. 单表更新
UPDATE用法:update 表名 set 属性1=value1,属性2=value2 where 限定条件
示例:
mysql> UPDATE product
-> SET price='20.00',type=0
-> WHERE proID=2;
Query OK, 1 row affected (0.04 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from product;
+-------+-------+------+---------------------+
| proID | price | type | dtime |
+-------+-------+------+---------------------+
| 1 | 10.00 | 0 | 2018-01-31 03:06:05 |
| 2 | 20.00 | 0 | 2018-01-31 03:06:05 |
| 3 | 10.00 | 1 | 2018-01-31 03:06:05 |
| 4 | 20.00 | 2 | 2018-01-31 03:06:05 |
| 5 | 30.00 | 3 | 2018-01-31 03:06:05 |
+-------+-------+------+---------------------+
5 rows in set (0.00 sec)
2. 关联更新
UPDATE用法:update 表名1,表名2 set 表1.属性=表2.属性值 where 限定条件
示例:
mysql> UPDATE producttype,product
-> SET producttype.amount=product.price
-> where product.TYPE = producttype.ID AND product.TYPE=1;
Query OK, 1 row affected (0.09 sec)
Rows matched: 1 Changed: 1 Warnings: 0 mysql> select * from producttype;
+----+--------+
| ID | amount |
+----+--------+
| 1 | 10 |
| 2 | NULL |
| 3 | NULL |
+----+--------+
3 rows in set (0.00 sec)
3. 限制更新
UPDATE用法:update 表名1,表名2 set 表1.属性=表2.属性值 where 限定条件 limit m
说明:只支持更新前多少行,而不支持非TOP的指定范围更新,也就是说,limit只接收一个参数。
意义:更新前m个符合where条件的记录。
mysql> UPDATE tb_name SET column_name='test' LIMIT ;
4. 排序更新
UPDATE用法:update 表名1,表名2 set 表1.属性=表2.属性值 where 限定条件 order by ... [limit m]
说明:同限制更新一样,首先判断出符合where条件的记录,然后对符合条件的记录进行排序,最后对排序后的前m条记录做更新
mysql> UPDATE tb_name SET column_name='test' ORDER BY id ASC LIMIT ;
5. 联合更新
UPDATE用法:update 表A set A.属性=表B.属性值 FROM a as A [inner join | right join | left join] b as B on [连接条件] where 限定条件
mysql> UPDATE Table_A
-> SET Table_A.col1 = Table_B.col1,
-> Table_A.col2 = Table_B.col2
-> FROM Some_Table AS Table_A
-> INNER JOIN Other_Table AS Table_B ON Table_A.id = Table_B.id
-> WHERE Table_A.col3 = 'cool';
mysql> update a join b on a.id=b.id set a.name=b.name where a.year=;
MySQL更新命令_UPDATE的更多相关文章
- MySQL命令大全:MySQL常用命令手册、MySQL命令行大全、查询工具
1.连接Mysql 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root ...
- 烂泥:mysql帮助命令使用说明
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 在安装.管理和使用mysql过程中,你是不是需要记忆很多的mysql命令.而且对于新手来说,很不多的命令不知道该如何应用,对于老手来说很多命令时间长了忘 ...
- Mysql常用命令详解
Mysql安装目录 数据库目录 /var/lib/mysql/ 配置文件 /usr/share/mysql(mysql.server命令及配置文件) 相关命令 /usr/bin(mysqladmin ...
- Mysql常用命令行大全
第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ...
- mysql常用命令(2)
1.连接Mysql 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL.首先打开DOS窗口,然后进入目录mysql\bin,再键入命令mysql -u root ...
- mysql常用命令(1)
Mysql安装目录数据库目录/var/lib/mysql/配置文件/usr/share/mysql(mysql.server命令及配置文件)相关命令/usr/bin(mysqladmin mysqld ...
- Mysql常用命令行大全——转载
转载地址:http://www.blogjava.net/supperchen/archive/2012/10/11/389340.html 第一招.mysql服务的启动和停止 net stop my ...
- mysql 常用命令(备忘)
1:使用SHOW语句找出在服务器上当前存在什么数据库: mysql> SHOW DATABASES; 2:2.创建一个数据库MYSQLDATA mysql> CREATE DATABASE ...
- MYSQL常用命令集合(转载)
文章出处:http://www.cnblogs.com/q1ng/p/4474501.html 1.导出整个数据库mysqldump -u 用户名 -p --default-character-set ...
随机推荐
- Cocos2dx项目在各种IDE中新建类之后的可行编译方式
注:这里说可行,但是并不是最好的,只是可以完成编译. 1.linux+code::blocks下的cocos2dx项目新建一个类TestScene.h 新建的TestScene.h和TestScene ...
- Oracle密码过期问题 ORA-28001:the password has expired
如果已经过期了,首先需要修改密码,然后设置密码为无限期.修改以sys用户登陆. 修改密码:alter user username identified by password 密码可以和之前的密码相 ...
- C#简单三层结构设计UI、BLL、DAL、Model实际项目应用例子
C#简单三层结构设计UI.BLL.DAL .Model实际项目应用例子 在实际项目中,程序设计都有他的层次结构,比如MVC.MVP.普通的三层结构等等,不过现在用三层结构的相比可能少了,但是也有一些小 ...
- ORACLE调优深入理解AWR报告(转)
AWR报告分析可从以下几点入手: (1).Oacle主机资源开销分析及负载情况 (2).oracle top信息分析 Top 10 Foreground Events by Total Wait Ti ...
- ArcGIS map preview in Power BI service
登录PowerBI网站:www.powerBI.com 点[设置],如下图: 找到[适用PowerBI的ArcGIS地图(预览)] 点击[应用]即可. 打开PowerBI DestTop客户端,找 ...
- 使用soap遇到的缓存问题
- php中,echo,print,var_dump的三个区别
1.echo语句 echo - 能够输出一个以上的字符串 <?php echo "<h2>www.dc3688.com</h2>"; ...
- 搭建svn服务器的坑
第一次搭建,能启动,就是连接不了 原因:修改配置文件(所有文字前面不能有空格,等号必须空格)
- MySQL的一些操作(学习记录_备忘)
有个问题一直困扰着我,就是在windows下,使用命令行登录mymql时,得cd进mysql的\bin目录下.但我已经将mysql的\bin加入了环境变量,似乎不起作用. mysql 不允许创建表名全 ...
- POJ 2248 - Addition Chains - [迭代加深DFS]
题目链接:http://bailian.openjudge.cn/practice/2248 题解: 迭代加深DFS. DFS思路:从目前 $x[1 \sim p]$ 中选取两个,作为一个新的值尝试放 ...