- 2
- 0
- 约8.28千字
- 约 9页
- 2019-11-20 发布于江苏
- 举报
PAGE / NUMPAGES
SQL语句的基本语法
一.SELECT语句的完整语法为:SELECT[ALL|DISTINCT|DISTINCTROW|TOP]{*|talbe.*|[table.]field1[AS alias1][,[table.]field2[AS alias2][,…]]}FROM tableexpression[,…][IN externaldatabase][WHERE…][GROUP BY…][HAVING…][ORDER BY…][WITH OWNERACCESS OPTION]说明:用中括号([])括起来的部分表示是可选的,用大括号({})括起来的部分是表示必须从中选择其中的一个。
1 FROM子句FROM子句指定了SELECT语句中字段的来源。FROM子句后面是包含一个或多个的表达式(由逗号分开),其中的表达式可为单一表名称、已保存的查询或由 INNER JOIN、LEFT JOIN 或 RIGHT JOIN 得到的复合结果。如果表或查询存储在外部数据库,在IN 子句之后指明其完整路径。例:下列SQL语句返回所有有定单的客户:SELECT OrderID,Customer.customerIDFROM Orders CustomersWHERE Orders.CustomerID=Customers.CustomeersID
2 ALL、DISTINCT、DISTINCTROW、TOP谓词(1) ALL 返回满足SQL语句条件的所有记录。如果没有指明这个谓词,默认为ALL。例:SELECT ALL FirstName,LastNameFROM Employees(2) DISTINCT 如果有多个记录的选择字段的数据相同,只返回一个。(3) DISTINCTROW 如果有重复的记录,只返回一个(4) TOP显示查询头尾若干记录。也可返回记录的百分比,这是要用 TOP N PERCENT子句(其中N 表示百分比)例:返回5%定货额最大的定单SELECT TOP 5 PERCENT*FROM [ Order Details]ORDER BY UnitPrice*Quantity*(1-Discount) DESC
3 用 AS 子句为字段取别名如果想为返回的列取一个新的标题,或者,经过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用AS保留。例:返回FirstName字段取别名为NickNameSELECT FirstName AS NickName ,LastName ,CityFROM Employees例:返回新的一列显示库存价值SELECT ProductName ,UnitPrice ,UnitsInStock ,UnitPrice*UnitsInStock AS valueInStockFROM Products
二 .WHERE 子句指定查询条件
1 比较运算符比较运算符 含义= 等于 大于 小于= 大于等于= 小于等于 不等于! 不大于! 不小于例:返回96年1月的定单SELECT OrderID, CustomerID, OrderDateFROM OrdersWHERE OrderDate#1/1/96# AND OrderDate#1/30/96#注意:Mcirosoft JET SQL 中,日期用‘#’定界。日期也可以用Datevalue()函数来代替。在比较字符型的数据时,要加上单引号’’,尾空格在比较中被忽略。例:WHERE OrderDate#96-1-1#也可以表示为:WHERE OrderDateDatevalue(‘1/1/96’)使用 NOT 表达式求反。例:查看96年1月1日以后的定单WHERE Not OrderDate=#1/1/96#
2 范围(BETWEEN 和 NOT BETWEEN)BETWEEN …AND…运算符指定了要搜索的一个闭区间。例:返回96年1月到96年2月的定单。WHERE OrderDate Between #1/1/96# And #2/1/96#
3 列表(IN ,NOT IN)IN 运算符用来匹配列表中的任何一个值。IN子句可以代替用OR子句连接的一连串的条件。例:要找出住在 London、Paris或Berlin的所有客户SELECT CustomerID, CompanyName, ContactName, CityFROM CustomersWHERE City In(‘London’,’ Paris’,’ Berlin’)
4 模式匹配(LIKE)LIKE运算符
原创力文档

文档评论(0)