MySql查询更新例子
2016-07-21 15:35
435 查看
一 创建表
创建一个表:CREATE TABLE `flower` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`color` varchar(255) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=latin1
插入如下数据:
1 blue
2 red
3 blue
4 red
5 blue
那么现在要求使用一个sql语句统计出来所有的red和blue的个数,
可以如下:
select
sum( case when color='red' then 1 else 0 end)as 'red',
sum( case when color='blue' then 1 else 0 end)as 'blue'
from flower
select count(1) as cnt,color from flower group by color
上面两个都可以。
一般公司都会把数据库作为存储介质而非逻辑运算。在这个例子中分多次起初数据。其实数据库是可以做到一次取出这类数据的。
在一个更新语句中使用查询语句
创建表如下:
CREATE TABLE `counter` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`counter` int(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=1018 DEFAULT CHARSET=latin1
录入如下数据:
1 83
3 4
5 45
6 32
7
8
9 83
10 4
现在如果想把id为1的counter列设置为所有的counter之和。那么,对于其他数据库产品,可以如下:
update counter c set counter=(select sum(counter) from counter)
但是,要注意的是,mysql根本就不支持在update语句中使用select语句【对于同一个表操作的情况】。
那么,在mysql下可以使用一个连接,这么写:
二、内连接查询更新
update counter c inner join (select sum(counter) as count_ from counter )as t set counter= t.count_ where c.id=1查询id大于5的个数
有一个表,id自增长,想查询id大于5的,那么很简单的可以写出来一个sql:
select count(*)
from table where id > 5
但是,这么写有什么问题呢。
在innodb表引擎中,这是必定要扫描全表的。【勘误2012-12-17---这里不知道当时脑袋秀逗了?怎么会写出这么傻x的错误。innodb只要有索引就不会全表扫描】
在myisam表引擎中,使用explain可以看到,这个sql语句访问了很多数据。而非仅仅小于5的那几个数据。可以优化如下:
explain select (select count(*) from counter )- count(*) from counter where id<=5
再次explain可以看到,Select tables optimized away,这次的sql使用了myisam的存储表数据个数的强项。
相关文章推荐
- mysql 正在使用的 my.cnf 配置文件的位置
- MySQL常用操作(留作备份)
- MySQL数据复制的校验
- MySQL详解--锁
- 关于mysql存当前时间
- mysql存储过程
- 设置MySQL开机自动启动的方法
- LAMP报PDO的错怎么办?
- mysql在MAC安装时忘记初始随机密码的解决办法
- 查看mysql版本的四种方法
- mysql开启root用户可远程登录方法
- mysql集群一:主从复制,通过mysql-proxy做负载均衡
- MySQL数据库引擎详解
- MySQL中if case条件语句基本用法
- mysql 主从故障恢复
- 详解mysql 存储过程
- MySQL 笔记 —— 日期和时间函数
- Haproxy+多台MySQL从服务器(Slave) 实现负载均衡
- powerdesign和mysql的相互转化
- My.ini的简单配置