zoukankan      html  css  js  c++  java
  • 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;

  • 相关阅读:
    数组的push()、pop()、shift()和unshift()方法
    Javascript的函数柯里化
    开闭原则
    字符串相等的判断
    String类常用的方法
    阅读API文档
    String类和常量池
    String基础
    内部类的分类
    内部类的概念
  • 原文地址:https://www.cnblogs.com/secbook/p/2655211.html
Copyright © 2011-2022 走看看