bryant

2006年11月7日 #

总结

 


 內連接INNER JOIN
Select a.* from bsempms a,bsdptms b where a.dpt_no=b.dpt_no;
外連接
Select a.* from bsempms a,bsdptms b where a.dpt_no=b.dpt_no;
Select a.* from bsempms a,bsdptms b wherea.dpt_no=b.dpt_no;

 

  快速清空一个表
SQL>truncate table table_name;

 IN 操作符
用IN写出来的SQL的优点是比较容易写及清晰易懂,这比较适合现代软件开发的风格。但是用IN的SQL性能总是比较低的,从ORACLE执行的步骤来分析用IN的SQL与不用IN的SQL有以下区别:
ORACLE试图将其转换成多个表的连接,如果转换不成功则先执行IN里面的子查询,再查询外层的表记录,如果转换成功则直接采用多个表的连接方式查询。由此可见用IN的SQL至少多了一个转换的过程。一般的SQL都可以转换成功,但对于含有分组统计等方面的SQL就不能转换了。在业务密集的SQL当中尽量不采用IN操作符。

NOT IN操作符
此操作是强列推荐不使用的,因为它不能应用表的索引。最好用NOT EXISTS 或(外连接+判断为空)方案代替

 

posted @ 2006-11-07 22:56 bgbg 阅读(76) | 评论 (0)编辑 收藏

仅列出标题