资源描述:
《SQL语句的基本语法.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、SQL语句的差不多语法一.SELECT语句的完整语法为:SELECT[ALL
2、DISTINCT
3、DISTINCTROW
4、TOP]{*
5、talbe.*
6、[table.]field1[ASalias1][,[table.]field2[ASalias2][,…]]}FROMtableexpression[,…][INexternaldatabase][WHERE…][GROUPBY…][HAVING…][ORDERBY…][WITHOWNERACCESS23/23OPTION]讲明:用中括号([])括起来的部分表示是可选的,用大括号({})括起来的部分是表示必须从中选
7、择其中的一个。1FROM子句FROM子句指定了SELECT语句中字段的来源。FROM子句后面是包含一个或多个的表达式(由逗号分开),其中的表达式可为单一表名称、已保存的查询或由INNERJOIN、LEFTJOIN或RIGHTJOIN得到的复合结果。假如表或查询存储在外部数据库,在IN子句之后指明其完整路径。例:下列SQL语句返回所有有定单的客户:SELECTOrderID,Customer.customerIDFROMOrdersCustomersWHEREOrders.CustomerID=Customers.CustomeersID2ALL、DISTINCT、
8、DISTINCTROW、TOP谓词(1)ALL返回满足SQL语句条件的所有记录。假如没有指明那个谓词,默认为ALL。例:SELECTALLFirstName,LastNameFROM23/23Employees(2)DISTINCT假如有多个记录的选择字段的数据相同,只返回一个。(3)DISTINCTROW假如有重复的记录,只返回一个(4)TOP显示查询头尾若干记录。也可返回记录的百分比,这是要用TOPNPERCENT子句(其中N表示百分比)例:返回5%定货额最大的定单SELECTTOP5PERCENT*FROM[OrderDetails]ORDERBYUnitP
9、rice*Quantity*(1-Discount)DESC3用AS子句为字段取不名假如想为返回的列取一个新的标题,或者,通过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用AS保留。例:返回FirstName字段取不名为NickNameSELECTFirstNameASNickName,LastName,CityFROMEmployees例:返回新的一列显示库存价值SELECT23/23ProductName,UnitPrice,UnitsInStock,UnitPrice*UnitsInStockASvalueInStockFROM
10、Products二.WHERE子句指定查询条件1比较运算符比较运算符含义=等于>大于<小于>=大于等于<=小于等于<>不等于!>不大于!<23/23不小于例:返回96年1月的定单SELECTOrderID,CustomerID,OrderDateFROMOrdersWHEREOrderDate>#1/1/96#ANDOrderDate<#1/30/96#注意:McirosoftJETSQL中,日期用‘#’定界。日期也能够用Datevalue()函数来代替。在比较字符型的数据时,要加上单引号’’,尾空格在比较中被忽略。例:WHEREOrderDate>#96-1-1
11、#也能够表示为:WHEREOrderDate>Datevalue(‘1/1/96’)使用NOT表达式求反。例:查看96年1月1日以后的定单WHERENotOrderDate<=#1/1/96#2范围(BETWEEN和NOTBETWEEN)BETWEEN23/23…AND…运算符指定了要搜索的一个闭区间。例:返回96年1月到96年2月的定单。WHEREOrderDateBetween#1/1/96#And#2/1/96#3列表(IN,NOTIN)IN运算符用来匹配列表中的任何一个值。IN子句能够代替用OR子句连接的一连串的条件。例:要找出住在London、Paris
12、或Berlin的所有客户SELECTCustomerID,CompanyName,ContactName,CityFROMCustomersWHERECityIn(‘London’,’Paris’,’Berlin’)4模式匹配(LIKE)LIKE运算符检验一个包含字符串数据的字段值是否匹配一指定模式。LIKE运算符里使用的通配符通配符含义?任何一个单一的字符*任意长度的字符#23/230~9之间的单一数字[字符列表]在字符列表里的任一值[!字符列表]不在字符列表里的任一值-指定字符范围,两边的值分不为其上下限例:返回邮政编码在(171)555-0000到(171)
13、555-9