当前位置:天才代写 > tutorial > 数据库教程 > 11个实用经典的SQL小贴士

11个实用经典的SQL小贴士

2018-05-18 08:00 星期五 所属: 数据库教程 浏览:586

  学习工作之余,在没有要解决问题的压力之下,还是建议系统的看看书,对于一些认为没啥用的知识点,也建议去仔细的看看,练练手,说不定什么时候就用到了,到时也好有针对性的去查,不至于盲目的按照自己的思路,重复的创造一些低效的解决方法。

  1.[]的使用

  当我们所要查的表是系统关键字或者表名中含有空格时,需要用[]括起来,例如新建了两个表,分别为user,userinfo,那么select*fromuser和select*fromuserinfo就要报错,需要写成:select*from[user]和select*from[userinfo],不过千万不要因为有[]的帮助,就随意起名了,那是自找麻烦,不过我确实看到有人把用户表起名为user的。

  2.NULLIF函数

  NULLIF(Expression1,Expression2):给定两个参数Expression1和Expression2,如果两个参数相等,则返回NULL;否则就返回第一个参数。

  等价于:CaseWHENExpression1=Expression2ThenNULLELSEExpression1。

  例如SelectNULLIF(1,1)返回NULL,SelectNULLIF(1,2)返回1。

  有一个实际的应用,例如防止除0操作的放生,可以使用a/NULLIF(b,0),这样就不怕b是0了,当然除0操作也可以通过别的方式判断。

  3.NULL

  NULL是个神奇的东西,表示空值,未知值,任何数与它加减乘除都返回NULL。

  4.ISNULL函数

  ISNULL(Expression1,Expression2):给定两个参数Expression1和Expression2,如果Expression1是NULL,那么返回Expression2,否则返回Expression1。

  等价于:CaseWHENExpression1isNULLThenExpression2ELSEExpression1。

  例如SelectISNULL(NULL,1)返回1,SelectISNULL(1,2)返回1。

  有一个实际的应用,可以对空值进行默认值替代,例如SELECTISNULL(email,’没有填写email’)fromtable1,所有email为null的,用’没有填写email’来替代。

  5.COALESCE函数

  COALESCE(Expression1,Expression2,Expression3,……):接受一系列的表达式或列,返回第一个非空的值。

  例如SELECTCOALESCE(NULL,NULL,4,NULL,NULL,5),那么返回4,如果里面的参数都为NULL,那么会报错。

  6.WITHTIES

  与top()和orderby一起用,可以返回多于top的行。防止丢失想要的信息。

  例如:有个表table1

  (1)select*fromtable1orderbynamedesc:结果如下:

select*fromtable1orderbynamedesc

  (2)selecttop(3)*fromtable1orderbynamedesc:结果如下:(只有三条)

(2)selecttop(3)*fromtable1orderbynamedesc:结果如下:(只有三条)

  (3)selecttop(3)withties*fromtable1orderbynamedesc:结果如下:

 (3)selecttop(3)withties*fromtable1orderbynamedesc:结果如下:

  7.ORDERBYNEWID():返回随机排序结果。

  8.BETWEENaANDb:返回大于等于a,小于等于b的结果。如果a>b,那么返回NULL。

  9.不要在where条件中使用函数,会强制每一行都计算该函数,无法使用索引查找。

  例如:select*fromtable1whereid+3>5和select*fromtable1whereid>5-3,后者效率比前者高。

  10.许多以_desc结尾的列,是为了更友好的表示一个列的含义。

  例如:SELECT*FROMsys.databases

 10.许多以_desc结尾的列,是为了更友好的表示一个列的含义。    例如:SELECT*FROMsys.databases

  11.推荐一个小插件,SQLPrompt,配合MicrosoftSQLServerManagementStudio,使用起来非常方便,同时再加上以下几个快捷键:

  (1)ctrl+5或F5,运行代码,如果想运行特定的语句,那么只是选中该语句,然后F5或ctrl+E即可。

  (2)ctrl+L:显示执行计划。

  (3)ctrl+R:显示隐藏下面的结果窗口,增大自己书写sql的空间。

  (4)ctrl+K,然后按Y,格式化SQL代码。

  看完11个实用经典的SQL小贴士,下面小编给大家安利另外关于SQL的一些小知识:

  1.在代码中调用存储过程的时,必须先测试存储过程,存储过程测试成功之后再去java中去调用!!@!@#!@!@!

  2.以后自己写的存储过程写一个本地保存一个.!~~~!!(这个很关键)

  3.以后在代码中的SQL都用LogUtil打印出来

  4.以后SQL有关的一律大写!!!!!!

  5.在Java中拼的SQL在结尾的时候不能写分号!!!!!!

  6.Select之后的别名不要跟数据库的列名字一样

  小编结语:

  更多内容尽在课课家教育!

  

 

    关键字:

天才代写-代写联系方式