MySql几个查询更新例子

一、
创建一个表:
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的存储表数据个数的强项。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值