SQL的几个编码规范


1.避免在where子句中对字段施加函数,这样将导致索引失效,比如:

select * from user where to_char(create_time,'yyyymmdd')='20090101';
原因:在建立index的时候是根据字段来建立的,也就是说oracle在inidex的时候是索引的字段的值,如果提供给oracle的是一个需要经过函数处理的比较,oracle就没办法通过索引中的索引键值来进行相应的比较,所以就不会走到索引上

2.避免在SQL中发生隐式类型转换

如:
select * from user where id='123'; --这里ID是NUMBER型,会造成oracle将id先转换成varchar类型再比较,造成索引失效
select * from user where gmt_create = to_char('2000-01-01','yyyy-mm-dd'); --这里gmt_create是date型,会造成oracle将gmt_create先转换成varchar类型再比较,造成索引失效

3.全模糊查询无法使用INDEX,应当尽可能避免

select * from user where name like '%value%';

4.如果使用Oracle数据库,使用Oracle的外连接,而不是标准的外连接语法

正确:select * from user1 a,user2 b where a.id=b.id(+);
错误:select * from user1 a left join on user2 b a.id=b.id;

5.分页语句必须使用三层嵌套的写法

select * from
(select rownum rn,a,* from
(select * from table where 条件 order by 条件) a
where rownum<=100) where rn>80;

posted @ 2010-01-15 13:42  MXi4oyu  阅读(134)  评论(0编辑  收藏  举报