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的行。防止丢失想要的信息。

例如:有个表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,后者效率比前者高。

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

例如:SELECT * FROM    sys.databases

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

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

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

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

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

11个常用的SQL技巧相关推荐

  1. mysql高级篇三:常用sql技巧

    文章目录 SQL执行顺序 正则表达式使用 MySQL 常用函数 SQL执行顺序 编写顺序 SELECT DISTINCT<select list> FROM<left_table&g ...

  2. 经典SQL语句大全、50个常用的sql语句

    50个常用的sql语句 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cname,T#) 课程表 SC(S#,C#,score) 成绩表 Teacher(T#,T ...

  3. MySQL性能调优与架构设计——第11章 常用存储引擎优化

    第11章 常用存储引擎优化 前言: MySQL 提供的非常丰富的存储引擎种类供大家选择,有多种选择固然是好事,但是需要我们理解掌握的知识也会增加很多.每一种存储引擎都有各自的特长,也都存在一定的短处. ...

  4. [转]javascript常用的小技巧

    javascript常用的小技巧 分类: javascript 2011-12-19 09:30 170人阅读 评论(1) 收藏 举报 事件源对象 event.srcElement.tagName e ...

  5. 你需要知道的20个常用的Python技巧

    点击上方"小白学视觉",选择加"星标"或"置顶" 重磅干货,第一时间送达 本文转自|机器学习算法那些事 Python的可读性和简单性是其广受 ...

  6. 常用经典SQL语句大全完整版--详解+实例 (存)

    常用经典SQL语句大全完整版--详解+实例 转 傻豆儿的博客 http://blog.sina.com.cn/shadou2012  http://blog.sina.com.cn/s/blog_84 ...

  7. mysql 10分钟_10分钟入门mysql(含常用的sql语句,mysql常见问题及解决方案)

    开发中常用的sql语句 1,创建一个数据库并指定编码格式 drop database if exists test;create database test default character set ...

  8. mysql+create+table+index_mysql------基础及常见SQL技巧

    基础 1.1 mysql表复制 复制表结构+复制表数据 mysql>create table t3 like t1; mysql>insert into t3 select * from ...

  9. sqlserver拼接sql插入table_10个SQL技巧

    介 绍 为了理解这 10 个 SQL 技巧的价值,首先需要了解下 SQL 语言的上下文.为什么我要在 Java 会议上讨论 SQL 呢?(我可能是唯一一个在 Java 会议上讨论 SQL 的了)下面讲 ...

最新文章

  1. 一个客户机-服务器系统使用了卫星网络,客户机/服务器体系结构可用于局域网、广域网和WWW。这三种用途迥异的网络的一个共同特点是工作负 - 试题答案网问答...
  2. java管理系统用怎么框架做_java 使用servlet做学生管理系统(无框架)
  3. 07/11/08 资料整理
  4. python代码规范化_最流行的Python代码规范
  5. Java新手造假_老板居然让我在Java项目中“造假”
  6. 交叉熵【度量两个概率分布间的差异性信息】
  7. Flutter ListView 下拉刷新与上拉加载更多
  8. golang goroutine协程运行机制及使用详解
  9. 企业传播的云计算时代还有多远?―21世纪广告―文章摘要―龙源期刊网
  10. 软件测试员200题(练习)
  11. Word样式窗格、模板格式
  12. 浅谈MATLAb中imcrop()函数
  13. 我的一些关于职场和职业发展的心得
  14. 一个由三角形引出的乘积恒等式
  15. iOS 百度地图_自定义Annotation大头针_修改大头针图片
  16. 烽火2640路由器命令行手册-14-桥接配置命令
  17. Python爬虫识别中文字符和标点符号
  18. 帖子浏览定位展开、收起标签js部分思路及代码
  19. [线段树]小喵喵的新家
  20. STM32WB系列调试总结

热门文章

  1. Linux下C++ UDP Socket例子
  2. HALCON示例程序high.hdev使用不同方法提取区域
  3. elementui el-from 怎样显示图片_vue2.0使用weui.js的uploader组件上传图片(兼容移动端)...
  4. cvc 降噪_耳机降噪功能这么多,说说什么是ANC、ENC、CVC、DSP降噪
  5. 可以进行单元测试么_前端与单元测试
  6. excel打开2个独立窗口_谢楠称女性独立的不是钱是心 谢楠与吴京婚后生育2个儿子...
  7. pandas删除某列有空值的行_Python-零基础学习Pandas知识点整理(2)
  8. oracle批量update数据_东方国信大数据面试真题
  9. csi python 摄像头 树莓派_树莓派之摄像头和人脸识别
  10. java的类属性默认有this 但容易与参数重名 所以需要显性的加上this 以分区别