适合初学者的MySQL学习笔记之SELECT语句使用详解 |
本文标签:MySQL SELECT语句 FROM子句 上次我们介绍了:适合初学者的MySQL学习笔记之MySQL常用命令操作技巧,本次我们介绍一下MySQL学习笔记之SELECT语句的使用方法,接下来就让我们一起来了解一下这部分内容吧 。 SELECT语句的完整语法为:
说明:用中括号([])括起来的部分表示是可选的,用大括号({})括起来的部分是表示必须从中选择其中的一个 。 1.FROM子句 FROM子句指定了SELECT语句中字段的来源 。FROM子句后面是包含一个或多个的表达式(由逗号分开),其中的表达式可为单一表名称、已保存的查询或由 INNER JOIN、LEFT JOIN 或RIGHT JOIN 得到的复合结果 。如果表或查询存储在外部数据库,在IN子句之后指明其完整路径 。 例:下列SQL语句返回所有有定单的客户:
2.ALL、DISTINCT、DISTINCTROW、TOP谓词 (1) ALL 返回满足SQL语句条件的所有记录 。如果没有指明这个谓词,默认为ALL 。例如:
(2) DISTINCT 如果有多个记录的选择字段的数据相同,只返回一个 。 (3) DISTINCTROW 如果有重复的记录,只返回一个 。 (4) TOP显示查询头尾若干记录 。也可返回记录的百分比,这是要用 TOP N PERCENT子句(其中N 表示百分比) 。 例:返回5%定货额最大的定单
3.用AS子句为字段取别名 如果想为返回的列取一个新的标题,或者,经过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用AS保留 。 例:返回FirstName字段取别名为NickName
例:返回新的一列显示库存价值
WHERE 子句指定查询条件 例:返回96年1月的定单
注意: Mcirosoft JET SQL 中,日期用‘#’定界 。日期也可以用Datevalue()函数来代替 。在比较字符型的数据时,要加上单引号’’,尾空格在比较中被忽略 。 例:WHERE OrderDate>#96-1-1# 使用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的所有客户
模式匹配(LIKE) LIKE运算符检验一个包含字符串数据的字段值是否匹配一指定模式 。 LIKE运算符里使用的通配符 通配符的含义 :
例:返回邮政编码在(171)555-0000到(171)555-9999之间的客户
关于适合初学者的MySQL学习笔记之SELECT语句的使用就介绍到这里了,希望本次的介绍能够对您有所收获! |