重温《MySQL必知必会》学习到的一些关键点(一)
1.谨慎使用select *
一般,除非你确实需要表中的每个列,否则最好别使用*通配符。虽然使用通配符可能会使你自己省事,不用明确列出所需列,但检索不需要的列通常会降低检索和应用程序的性能。
2.检索不同的行——DISTINCT关键字
不能部分使用DISTINCT DISTINCT关键字应用于所有列而不仅是前置它的列。如果给出SELECT DISTINCT vend_id, prod_price,除非指定的两个列都不同,否则所有行都将被检索出来
3.限制结果——LIMIT关键字
(1)SELECT prod_name FROM products LIMIT 5;此语句使用SELECT语句检索单个列。LIMIT 5指示MySQL返回不多于5行。
(2)SELECT prod_name FROM products LIMIT 5,5;LIMIT 5, 5指示MySQL返回从行5开始的5行。第一个数为开始位置,第二个数为要检索的行数。
注意:检索出来的第一行为行0而不是行1。因此,LIMIT 1, 1
将检索出第二行而不是第一行。
4.ORDER BY 默认按照升序对记录进行排序;为了进行降序排序,必须指定DESC关键字。
注意:DESC关键字只应用到直接位于其前面的列名。
列如SELECT c1,c2,c3 FROM table ORDER BY c1,c2 DESC这表示按照c1升序排列。按照c2降序排列
5.ORDER BY与LIMIT的结合
如:SELECT c1 FROM table ORDER BY c1 DESC LIMIT 1
表示查询 table 中按c1字典顺序排列最大的一行。要注意ORDER BY子句的位置,在给出ORDER BY子句时,应该保证它
位于FROM子句之后。如果使用LIMIT,它必须位于ORDER BY
之后。使用子句的次序不对将产生错误消息。
6.使用WHERE子句
(1)SQL过滤与应用过滤:数据也可以在应用层过滤。为此目的,SQL的SELECT语句为客户机应用检索出超过实际所需的数据,然后客户机代码对返回数据进行循环,以提取出需要的行。通常,这种实现并不令人满意。因此,对数据库进行了优化,以便快速有效地对数据进行过滤。让客户机应用(或开发语言)处理数据库的工作将会极大地影响应用的性能,并且使所创建的应用完全不具备可伸缩性。此外,如果在客户机上过滤数据,服务器不得不通过网络发送多余的数据,这将导致网络带宽的浪费。
(2)在同时使用ORDER BY和WHERE子句时,应该让ORDER BY位于WHERE之后,否则将会产生错误.
7.空值检查
NULL:无值(no value),它与字段包含0、空字符串或仅仅包含空格不同。
采用:WHERE column IS NULL来检查。
NULL与不匹配:在通过过滤选择出不具有特定值的行时,你可能希望返回具有NULL值的行。但是,不行。因为未知具有特殊的含义,数据库不知道它们是否匹配,所以在匹配过滤或不匹配过滤时不返回它们。 因此,在过滤数据时,一定要验证返回数据中确实给出了被过滤列具有NULL的行。
8.AND与OR的优先级
AND的优先级高于OR
在WHERE子句中使用圆括号:任何时候使用具有AND和OR操作符的WHERE子句,都应该使用圆括号明确地分组操作符。不要过分依赖默认计算次序,即使它确实是你想要的东西也是如此。使用圆括号没有什么坏处,它能消除歧义。
9.IN可以替代OR,使用IN操作符的优势:
- 在使用长的合法选项清单时,IN操作符的语法更清楚且更直观。
- 在使用IN时,计算的次序更容易管理(因为使用的操作符更少)。
- IN操作符一般比OR操作符清单执行更快。
- IN的最大优点是可以包含其他SELECT语句,使得能够更动态地建立WHERE子句。(后续介绍)
10.NOT取反
MySQL中的NOT MySQL支持使用NOT对IN、BETWEEN和EXISTS子句取反,这与多数其他DBMS允许使用NOT对各种条件取反有很大的差别。
11.LIKE操作符与通配符
1)百分号(%)通配符,区分大小写。%代表搜索模式中给定位置的0个、1个或多个字符。
(2)下划线(_)通配符,区分大小写。下划线的用途与%一样,但下划线只匹配单个字符而不是多个字符。
(3) 使用通配符的技巧。
不要过度使用通配符。如果其他操作符能达到相同的目的,应该使用其他操作符。
在确实需要使用通配符时,除非绝对有必要,否则不要把它们用在搜索模式的开始处。把通配符置于搜索模式的开始处,搜索起来是最慢的。
仔细注意通配符的位置。如果放错地方,可能不会返回想要的数据。
12.使用MySQL正则表达式
(1)关键字:REGEXP
(2)基本字符匹配。REGEXP ‘字符串’
(3)LIKE和REGEXP的区别:
LIKE与REGEXP 在LIKE和REGEXP之间有一个重要的差别。LIKE匹配整个列。如果被匹配的文本在列值中出现,LIKE将不会找到它,相应的行也不被返回(除非使用通配符)。而REGEXP在列值内进行匹配,如果被匹配的文本在列值中出现,REGEXP将会找到它,相应的行将被返回。 REGEXP使用^和$定位符(anchor)用来匹配整个列值。
(4)匹配不区分大小写。 MySQL中的正则表达式匹配(自版本3.23.4后)不区分大小写(即,大写和小写都匹配)。为区分大小写,可使用BINARY关键字,如WHERE prod_name REGEXP BINARY ‘JetPack .000’。
(4)进行OR匹配。 1000|2000。|为正则表达式的OR操作符。它表示匹配其中之一,因此1000和2000都匹配并返回。
(5)匹配几个字符之一。使用[abc]表示匹配a或b或c。使用[^abc]却匹配除这些字符外的任何东西。
(6)匹配范围。匹配[012345]这样的集合,可以用[0-5]来进行匹配。
(7)匹配特殊字符。使用转义字符“//”,如“//.”表示匹配字符“.”。
(8)匹配字符类。存在找出经常使用的数字、所有字母字符或所有数字字母字符等的匹配。
(9)匹配多个实例。使用场景:可能需要寻找所有的数,不管数中包含多少数字,或者可能想寻找一个单词并且还能够适应一个尾随的s(如果存在),等等。
(10)定位符。为了匹配特定位置的文本,需要使用表9-4列出的定位符。
第一章到第九章的学习完毕,后续的章节将后在后面的博客中写出。