《SQL必知必会——第3、4、5课:排序检索数据及过滤数据》

       第3课  排序检索数据

       这一课主要讲order by用法,看似很简单,实际有些细节还可以说说。

       order by子句的位置:在指定一条order by子句时,应该保证它是select语句中的最后一条子句,否则将会出错。

       order by按多个列排序:指定列名,列名之间用逗号分开即可;除此之外,还可以按照相对位置排序,比如order by 2, 3,即先按表的第2列,在按照表的第3列排序,由于是序号而非列名,可能会搞错,这种用法平时用的也比较少 。

       指定排序方向:也就是升序和降序。升序是asc(ascending),降序是desc(descending),升序是默认的,可以不用指定。如果需要降序输出,则需要指定desc,比如order by price desc,这里面desc关键字作用范围仅限于其前面的列名,也就是说order by price desc,name,将按照价格price降序排序,然后按照名称name升序排序。

       这一课差不多这些知识点,order by还是比较好理解的。

       第4、5课  过滤数据

       过滤数据自然就是讲where用法。where子句有很多操作符,等于:=、不等于:<> 或 !=、 大于:>、大于等于:>=、小于:<、小于等于:<=、between、is null等。上述操作符有些dbms不支持,因为每家dbms风格也是有一点点不同的,如:access支持<>而不支持!=。上面操作符,between属于范围检查操作符,使用时需要和and关键字搭配使用,同时还需要制定范围的低端值和高端值,如:select name, price from products where price between 5 and 10;

       空值检查

       编程过程中,所有工程师都无法逃避的一个问题,那就是空值检查,c和c++尤其多,java虽然不用指针,但是照样需要做大量的空值检查,为此很多编程语言专门设计了空值检查类或者关键字。和在程序中不同,在数据库中,空值指的是在一个列不包含值时,称其包含空值NULL。空值也就是无值,而0、空字符串、空格等等,这都是值,不能与NULL划等号,所以,在设计数据库时,NULL值与0和空字符串,是完全不同的。检查空值需使用is null操作符,如:select name, price from products where price is null;

       组合where子句

       过滤数据,可以理解成就是if操作,if操作有与&&和或||,那么自然where子句也有and和or,也就是组合更多的条件来过滤数据。and操作符,也就是&&操作,表示检索满足所有给定条件的数据。or操作符,也就是||操作,用来表示检索匹配任一给定条件的行。那么and和or一起用会怎么样呢?if中 && 和 || 一起用会怎么样,它就会怎么样。所以,为了避免出现歧义,建议使用圆括号()明确地将各个条件括起来,就像写if判断一样,避免出现由于求值顺序问题导致的数据查询错误。

       说完了and和or,在说说in操作符。in操作符用来指定条件范围,范围中的每个条件都可以进行匹配。如:select name,price from products where name in ('mac pro', 'think pad'),其实就是or操作符所执行的功能,一样一样的。但是,很明显一个in可以搞定,省去了很多or,sql语句更简洁了,还有更重要的,那就是in操作符比一组or操作符执行更快。

       最后说一下not操作符,这个操作符可以理解成就是平时编程时用的!操作符,连使用位置都一样,都是放在前面。也就是要过滤的列前面。比如:select name,price from products where not name = 'mac pro'; 这样一看,似乎not操作符并没什么卵用,因为上面完全可以这样写:select name,price from products where name != 'mac pro'; 但是当not与其他操作符联合使用时,威力才能发挥出来,比如和in一起,not in,就可以找出与条件列表不匹配的数据,如:select name,price from products where name not in ('mac pro', 'think pad')。越复杂的sql,这些操作符越能发挥出威力,当然还是尽量避免写太复杂的sql。

猜你喜欢

转载自blog.csdn.net/u013085897/article/details/81262691