国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

SQL語句的基本語法一

2024-07-21 02:34:37
字體:
來源:轉載
供稿:網友

  一.SELECT語句的完整語法為:
  
  SELECT[ALLDISTINCTDISTINCTROWTOP]
  {*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.customerID
  FROM Orders Customers
  WHERE Orders.CustomerID=Customers.CustomeersID
  
  2 ALL、DISTINCT、DISTINCTROW、TOP謂詞
  
  (1) ALL 返回滿足SQL語句條件的所有記錄。假如沒有指明這個謂詞,默認為ALL。
  
  例:SELECT ALL FirstName,LastName
  FROM   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字段取別名為NickName
  SELECT  FirstName AS NickName ,LastName ,City
  FROM   Employees
  
  例:返回新的一列顯示庫存價值
  SELECT ProdUCtName ,UnitPrice ,UnitsInStock ,UnitPrice*UnitsInStock AS valueInStock
  FROM  Products
  
  二 .WHERE 子句指定查詢條件
  
  1 比較運算符
  
  比較運算符 含義
  = 等于
  > 大于
  < 小于
  >= 大于等于
  <= 小于等于
  <> 不等于
  !> 不大于
  !< 不小于
  
  例:返回96年1月的定單
  
  SELECT OrderID, CustomerID, OrderDate
  FROM Orders
  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#
  
  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, City
  FROM Customers
  WHERE City In(‘London’,’ Paris’,’ Berlin’)
  
  4 模式匹配(LIKE)
  
  LIKE運算符檢驗一個包含字符串數據的字段值是否匹配一指定模式。
  
  LIKE運算符里使用的通配符
  
  通配符 含義
  
 ??? 任何一個單一的字符
  * 任意長度的字符
  # 0~9之間的單一數字
  [字符列表] 在字符列表里的任一值
  [!字符列表] 不在字符列表里的任一值
  - 指定字符范圍,兩邊的值分別為其上下限
  例:返回郵政編碼在(171)555-0000到(171)555-9999之間的客戶
  SELECT CustomerID ,CompanyName,City,Phone
  FROM Customers
  WHERE Phone Like ‘(171)555-####’
  LIKE運算符的一些樣式及含義
  樣式 含義 不符合
  LIKE ‘A*’ A后跟任意長度的字符 Bc,c255
  LIKE’5[*]’ 5*5 555
  LIKE’5?5’ 5與5之間有任意一個字符 55,5wer5
  LIKE’5##5’ 5235,5005 5kd5,5346
  LIKE’[a-z]’ a-z間的任意一個字符 5,%
  LIKE’[!0-9]’ 非0-9間的任意一個字符 0,1
  LIKE’[[]’ 1,*
  
  三 .用ORDER BY子句排序結果
  
  ORDER子句按一個或多個(最多16個)字段排序查詢結果,可以是升序(ASC)也可以是降序(DESC),缺省是升序。ORDER子句通常放在SQL語句的最后。
  
  ORDER子句中定義了多個字段,則按照字段的先后順序排序。
  
  例:
  SELECT ProductName,UnitPrice, UnitInStock
  FROM  Products
  ORDER BY  UnitInStock DESC , UnitPrice DESC, ProductName
  
  ORDER BY 子句中可以用字段在選擇列表中的位置號代替字段名,可以混合字段名和位置號。
  
  例:下面的語句產生與上列相同的效果。
  
  SELECT ProductName,UnitPrice, UnitInStock
  FROM  Products
  ORDER BY  1 DESC , 2 DESC,3
  
  四 .運用連接關系實現多表查詢
  
  例:找出同一個城市中供給商和客戶的名字
  
  SELECT Customers.CompanyName, Suppliers.ComPany.Name
  FROM  Customers, Suppliers
  WHERE Customers.City=Suppliers.City
  
  例:找出產品庫存量大于同一種產品的定單的數量的產品和定單
  
  SELECT ProductName,OrderID, UnitInStock, Quantity
  FROM  Products, [Order Deails]
  WHERE Product.productID=[Order Details].ProductID
  AND UnitsInStock>Quantity
  
  另一種方法是用 Microsof JET SQL 獨有的 JNNER JOIN
  
  語法:
  
  FROM table1 INNER JOIN table2
  ON   table1.field1 comparision table2.field2
  
  其中comparision 就是前面WHERE子句用到的比較運算符。
  
  SELECT FirstName,lastName,OrderID,CustomerID,OrderDate
  FROM Employees
  INNER JOIN Orders ON Employees.EmployeeID=Orders.EmployeeID
  
  注重:
  
  INNER JOIN不能連接Memo OLE Object Single Double 數據類型字段。
  
  在一個JOIN語句中連接多個ON子句
  
  語法:
  SELECT fields
  FROM table1 INNER JOIN table2
  ON table1.field1 compopr table2.field1 AND
  ON table1.field2 compopr table2.field2 OR
  ON table1.field3 compopr table2.field3
  也可以
  SELECT fields
  FROM table1 INNER JOIN
 ?。╰able2 INNER JOIN [( ]table3
  [INNER JOER] [( ]tablex[INNER JOIN]
  ON table1.field1 compopr table2.field1
  ON table1.field2 compopr table2.field2
  ON table1.field3 compopr table2.field3
  
  外部連接返回更多記錄,在結果中保留不匹配的記錄,不管存不存在滿足條件的記錄都要返回另一側的所有記錄。

  
  FROM table [LEFTRIGHT]JOIN table2
  ON table1.field1comparision table.field2
  
  用左連接來建立外部連接,在表達式的左邊的表會顯示其所有的數據
  
  例:不管有沒有定貨量,返回所有商品
  
  SELECT   ProductName ,OrderID
  FROM   Products
  LEFT JOIN Orders  ON  Products.PrductsID=Orders.ProductID

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 商丘市| 阿拉善盟| 汝南县| 抚州市| 逊克县| 阳原县| 玉田县| 织金县| 涿州市| 云霄县| 曲阜市| 宁乡县| 南川市| 曲水县| 沁阳市| 长子县| 三门峡市| 兰考县| 穆棱市| 朝阳区| 华蓥市| 柳江县| 水城县| 乌审旗| 巨野县| 张家口市| 富平县| 邮箱| 社会| 昌图县| 新余市| 通许县| 杭锦后旗| 金山区| 大城县| 比如县| 江城| 北安市| 济南市| 洛扎县| 延长县|