sql 的小知识
来源:互联网 发布:静力学有限元分析软件 编辑:程序博客网 时间:2024/06/06 05:26
1.[]的使用
当我们所要查的表是系统关键字或者表名中含有空格时,需要用[]括起来,例如新建了两个表,分别为user,user info,那么select * from user和select * from user info就要报错,需要写成:select * from [user] 和 select * from [user info],不过千万不要因为有[]的帮助,就随意起名了,那是自找麻烦,不过我确实看到有人把用户表起名为user的。
2.NULLIF函数
NULLIF(Expression1,Expression2):给定两个参数Expression1和Expression2,如果两个参数相等,则返回NULL;否则就返回第一个参数。
等价于:Case WHEN Expression1=Expression2 Then NULL ELSE Expression1。
例如Select NULLIF(1,1)返回NULL,Select NULLIF(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。
等价于:Case WHEN Expression1 is NULL Then Expression2 ELSE Expression1。
例如Select ISNULL(NULL,1)返回1,Select ISNULL(1,2)返回1。
有一个实际的应用,可以对空值进行默认值替代,例如SELECT ISNULL(email,'没有填写email') from table1,所有email为null的,用'没有填写email'来替代。
5.COALESCE函数
COALESCE(Expression1,Expression2,Expression3,......):接受一系列的表达式或列,返回第一个非空的值。
例如SELECT COALESCE(NULL,NULL,4,NULL,NULL,5),那么返回4,如果里面的参数都为NULL,那么会报错。
6.WITH TIES
与top()和order by 一起用,可以返回多于top的行。防止丢失想要的信息。
select top(3) * from t_sys_user order by org_id desc
select * from t_sys_user order by org_id desc
select top(3) with ties * from t_sys_user order by org_id desc
例如:有个表table1
(1)select * from table1 order by name desc :结果如下:
(2)select top(3) * from table1 order by name desc:结果如下:(只有三条)
(3)select top(3) with ties * from table1 order by name desc:结果如下:
7.ORDER BY NEWID():返回随机排序结果。
8.BETWEEN a AND b:返回大于等于a,小于等于b的结果。如果a>b,那么返回NULL。
9.不要在where条件中使用函数,会强制每一行都计算该函数,无法使用索引查找。
例如:select * from table1 where id+3>5和select * from table1 where id>5-3,后者效率比前者高。
- sql 的小知识
- SQL管理的小知识
- SQL游标的小知识
- 关于 SQL 和 Recordset 的小知识
- 关于 SQL 和 Recordset 的小知识
- sql server 2000 的小知识
- 你不知道的sql小知识
- sql小知识
- SQL小知识
- sql常用小知识
- SQL 小知识
- 几个sql小知识
- sql 小知识
- SQL注入一点小知识
- sql常用小知识 ---ISNULL
- SQL Server 2008小知识
- 数据库sql语句小知识
- oracle pl/sql 小知识
- Extjs表单常见验证小结
- Android CardView使用
- iOS提交AppStore出现ERROR ITMS-90530 And ITMS-90502
- 第十四周【项目二-二叉树排序树中查找的路径】
- 【Matplotlib】概要总览第一讲
- sql 的小知识
- 亲自试验成功-手动安装Emmet插件
- APP数据分析体系
- Linear Algebra - Lesson 21. 特征值和特征向量
- MYSQL批量删除表
- windows install lxml for scrapy
- TCP/IP、Http、Socket的区别
- 润乾报表v4-Demo中正常的打印导出导入参数功能集成后不能用的特殊情况解决
- 进程调度——简单轮转算法