适合初学者的MySQL学习笔记之SELECT语句使用详解

数据库 MySQL
本文我们主要介绍了适合初学者的MySQL学习笔记之SELECT语句的使用,以及WHERE子句查询和LIKE通配符的使用实例,希望能够对您有所帮助。

上次我们介绍了:适合初学者的MySQL学习笔记之MySQL常用命令操作技巧,本次我们介绍一下MySQL学习笔记之SELECT语句的使用方法,接下来就让我们一起来了解一下这部分内容吧。

SELECT语句的完整语法为:

  1. SELECT[ALL|DISTINCT|DISTINCTROW|TOP]   
  2. {*|talbe.*|[table.]field1[AS alias1][,[table.]field2[AS alias2][,…]]}   
  3. FROM tableexpression[,…][IN externaldatabase]   
  4. [WHERE…]   
  5. [GROUP BY…]   
  6. [HAVING…]   
  7. [ORDER BY…]   
  8. [WITH OWNERACCESS OPTION] 

说明:用中括号([])括起来的部分表示是可选的,用大括号({})括起来的部分是表示必须从中选择其中的一个。

1.FROM子句

FROM子句指定了SELECT语句中字段的来源。FROM子句后面是包含一个或多个的表达式(由逗号分开),其中的表达式可为单一表名称、已保存的查询或由 INNER JOIN、LEFT JOIN 或RIGHT JOIN 得到的复合结果。如果表或查询存储在外部数据库,在IN子句之后指明其完整路径。

例:下列SQL语句返回所有有定单的客户:

  1. SELECT OrderID,Customer.customerID   
  2. FROM Orders Customers   
  3. WHERE Orders.CustomerID=Customers.CustomeersID 

2.ALL、DISTINCT、DISTINCTROW、TOP谓词

(1) ALL 返回满足SQL语句条件的所有记录。如果没有指明这个谓词,默认为ALL。例如:

  1. SELECT ALL FirstName,LastName   
  2. FROM Employees  

(2) DISTINCT 如果有多个记录的选择字段的数据相同,只返回一个。

(3) DISTINCTROW 如果有重复的记录,只返回一个。

(4) TOP显示查询头尾若干记录。也可返回记录的百分比,这是要用 TOP N PERCENT子句(其中N 表示百分比)。

例:返回5%定货额***的定单

  1. SELECT TOP 5 PERCENT*   
  2. FROM [ Order Details]   
  3. ORDER BY UnitPrice*Quantity*(1-Discount) DESC 

3.用AS子句为字段取别名 

如果想为返回的列取一个新的标题,或者,经过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用AS保留。

例:返回FirstName字段取别名为NickName

  1. SELECT FirstName AS NickName ,LastName ,City   
  2. FROM Employees  

例:返回新的一列显示库存价值

  1. SELECT ProductName ,UnitPrice ,UnitsInStock ,UnitPrice*UnitsInStock AS valueInStock   
  2. FROM Products 

WHERE 子句指定查询条件

例:返回96年1月的定单

  1. SELECT OrderID, CustomerID, OrderDate   
  2. FROM Orders   
  3. WHERE OrderDate>#1/1/96# AND OrderDate<#1/30/96#  

注意:

Mcirosoft JET SQL 中,日期用‘#’定界。日期也可以用Datevalue()函数来代替。在比较字符型的数据时,要加上单引号’’,尾空格在比较中被忽略。 例:WHERE OrderDate>#96-1-1#
也可以表示为: WHERE OrderDate>Datevalue(‘1/1/96’)

使用NOT表达式求反:

例:查看96年1月1日以后的定单:WHERE Not OrderDate<=#1/1/96#

范围(BETWEEN 和 NOT BETWEEN):

BETWEEN …AND…运算符指定了要搜索的一个闭区间。

例:返回96年1月到96年2月的定单:WHERE OrderDate Between #1/1/96# And #2/1/96#

列表(IN ,NOT IN):

IN 运算符用来匹配列表中的任何一个值。IN子句可以代替用OR子句连接的一连串的条件。

例:要找出住在 London、Paris或Berlin的所有客户

  1. SELECT CustomerID, CompanyName, ContactName, City   
  2. FROM Customers   
  3. WHERE City In(‘London’,’ Paris’,’ Berlin’)  

模式匹配(LIKE)

LIKE运算符检验一个包含字符串数据的字段值是否匹配一指定模式。

LIKE运算符里使用的通配符

通配符的含义 :

  • ? 任何一个单一的字符
  • * 任意长度的字符
  • # 0~9之间的单一数字
  • [字符列表] 在字符列表里的任一值
  • [!字符列表] 不在字符列表里的任一值
  • - 指定字符范围,两边的值分别为其上下限

例:返回邮政编码在(171)555-0000到(171)555-9999之间的客户

  1. SELECT CustomerID ,CompanyName,City,Phone   
  2. FROM Customers   
  3. WHERE Phone Like ‘(171)555-#### 

关于适合初学者的MySQL学习笔记之SELECT语句的使用就介绍到这里了,希望本次的介绍能够对您有所收获!

【编辑推荐】

  1. 介绍六个有用的MySQL的SQL语句
  2. MySQL大数据量快速插入方法和语句优化
  3. MySQL数据库完整备份与增量备份的原理简介
  4. 六条比较有用的MySQL数据库操作的SQL语句
  5. 详解xtrabackup对MySQL进行备份和恢复的全过程

 

责任编辑:赵鹏 来源: 博客园
相关推荐

2011-08-16 16:10:12

MySQLORDER BY子句GROUP BY子句

2011-08-16 14:43:57

MySQL查询初学者

2011-08-16 14:14:22

MySQL数据库初学者

2011-08-16 13:59:42

MySQL初学者表的操作

2011-08-16 13:33:13

MySQL数据库初学者

2011-08-16 15:19:21

2011-08-16 15:04:41

MySQL数据库管理员常用操作

2021-12-09 05:58:51

编程语言开发代码

2011-06-21 10:44:31

const

2011-07-26 17:55:16

iPhone Runtime

2009-09-28 09:45:00

CCNA学习经验CCNA

2015-07-20 13:56:59

SDN

2020-09-08 19:03:41

Java代码初学者

2023-10-25 16:16:27

2011-08-29 15:45:59

Lua函数

2020-05-10 16:59:56

Python装饰器开发

2011-08-23 14:01:03

LUA

2011-08-01 16:10:00

SQL Server

2019-07-25 13:12:26

Linux发行版
点赞
收藏

51CTO技术栈公众号