2013第49周二要转变
2013-12-03 20:21
211 查看
2013第49周二要转变今天中午考虑了很多,关于写随笔方便我应该注意以下两点: 1.注意排版,写的任何东西都要注意排版,就如同人要注意形象。 2.要注意突出重点,写的东西最重要还是自己要看,突出重点也有利于自己后期阅读,同时可敦促自己不要应付。自我感觉今天开发效率还可以,下午又开始了一个新模块的开发,并已完成sql语句和dao层部分,其中用到了mysql语句的union和order by 关键字mysql union要求:两次查询的列数必须一致
推荐:列的类型可以不一样,但推荐查询的每一列,想对应的类型一样
可以来自多张表的数据:多次sql语句取出的列名可以不一致,此时以第一个sql语句的列名为准。
如果不同的语句中取出的行,有完全相同(这里表示的是每个列的值都相同),那么union会将相同的行合并,最终只保留一行。也可以这样理解,union会去掉重复的行。
如果不想去掉重复的行,可以使用union all。
如果子句中有order by,limit,需用括号()包起来。推荐放到所有子句之后,即对最终合并的结果来排序或筛选。
如:(select * from a order by id) union (select * from b order id);
在子句中,order by 需要配合limit使用才有意义。如果不配合limit使用,会被语法分析器优化分析时去除。
select * from test1 where name like 'A%' order by name
union
select * from test1 where name like 'B%' order by name
应改为:
select * from test1 where name like 'A%'
union
select * from test1 where name like 'B%' order by name
因为union中,在不用括号的情况下,只能用一个order by(想一想,如果union两边的order by的列名不一样会怎么样),这会对union后的结果集进行排序
或者改为:
(select * from test1 where name like 'A%' order by name)
union
(select * from test1 where name like 'B%' order by name)
这两个order by在union前进行
select * from test1 where name like 'A%' limit 10
union
select * from test1 where name like 'B%' limit 20
相当于
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%') limit 20
即后一个limit作用于的是union后的结果集,而不是union后的select
也可以加括号来得到你想要的结果
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%' limit 20)
推荐:列的类型可以不一样,但推荐查询的每一列,想对应的类型一样
可以来自多张表的数据:多次sql语句取出的列名可以不一致,此时以第一个sql语句的列名为准。
如果不同的语句中取出的行,有完全相同(这里表示的是每个列的值都相同),那么union会将相同的行合并,最终只保留一行。也可以这样理解,union会去掉重复的行。
如果不想去掉重复的行,可以使用union all。
如果子句中有order by,limit,需用括号()包起来。推荐放到所有子句之后,即对最终合并的结果来排序或筛选。
如:(select * from a order by id) union (select * from b order id);
在子句中,order by 需要配合limit使用才有意义。如果不配合limit使用,会被语法分析器优化分析时去除。
select * from test1 where name like 'A%' order by name
union
select * from test1 where name like 'B%' order by name
应改为:
select * from test1 where name like 'A%'
union
select * from test1 where name like 'B%' order by name
因为union中,在不用括号的情况下,只能用一个order by(想一想,如果union两边的order by的列名不一样会怎么样),这会对union后的结果集进行排序
或者改为:
(select * from test1 where name like 'A%' order by name)
union
(select * from test1 where name like 'B%' order by name)
这两个order by在union前进行
select * from test1 where name like 'A%' limit 10
union
select * from test1 where name like 'B%' limit 20
相当于
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%') limit 20
即后一个limit作用于的是union后的结果集,而不是union后的select
也可以加括号来得到你想要的结果
(select * from test1 where name like 'A%' limit 10)
union
(select * from test1 where name like 'B%' limit 20)
相关文章推荐
- 2013第45周二忙碌的一天
- 2013第52周二开发记
- 第49周二
- 2013第3周二Java后台学习
- 2017第49周二乌镇互联网大会总结
- 2013第49周一jsp标签
- 2013第49周六多做有益的沟通
- 2013--转变
- 2013第50周二eclipse工具尝试
- 2013第47周二一天忙碌的开发
- 2013第35周二平淡一天
- 2013--转变
- 2013第5周二最后半小时郁闷中
- 2015第49周二
- 我的2013-一个dota半职业玩家向码农的转变路
- 2013第49周三IE9文档模式
- 2016第49周二
- 2013:由工地到IT的转变
- 网易2013实习生试题 第五题
- SharePoint 2013 工作流设计之Designer 使用“可视化视图”