jetsql
⑴ case when用法sql
在SQL中,「Case When」語句用法如下:
在SQL中,「Case When」語句用於選擇判斷,在執行時先對條件進行判斷,然後根據判斷結果做出相應的操作;語法「CASE 欄位 WHEN 條件1 THEN 操作啟沒1 WHEN 條件2 THEN 操作擾州2...ELSE 操作n END;」。
此外,SQL 也有一些變種,就像中文有很多方言,比如:
微軟的 SQL Server 使用 T-SQL;
Oracle 使用 PL/SQL;
微軟 Access 版本的 SQL 被稱為 JET SQL(本地格式)。
⑵ jet sql 和 ansi sql 的主要區別是什麼 他們都代表什麼
Microsoft Jet SQL 和 ANSI SQL 的比較
Microsoft Jet 數據引擎 SQL 總體上跟 ANSI-89 Level 1 是兼容的,但某些 ANSI SQL 性能在 Microsoft Jet SQL 里沒有實現。 Microsoft 發布的 Jet 4.X 版本,以及「Microsoft OLE DB Provider for Jet」 推出了更多的 ANSI-92 SQL 語法。在另一方面,Microsoft Jet SQL 包含了 ANSI SQL 不支持的保留字和性能。
主要的不同
Microsoft Jet SQL 和 ANSI SQL 各自有不同的保留字和數據類型。可參考下列鏈接:
List of Microsoft Jet 4.0 reserved words
Equivalent ANSI SQL Data Types
對於下面所示的語法結構應用的規則不一樣:
expr1 [NOT] Between value1 And value2
在 Microsoft Jet SQL 中,value1 可以比 value2 大;在 ANSI SQL 中, value1 一定要小於等於 value2
當我們用 Like 操作符進行模糊查詢時,Microsoft Jet SQL 既支持 ANSI SQL 的通配符,也支持 Microsoft Jet 特有的通配符。但是 ANSI 和 Microsoft Jet 的通配符是互斥的,我們只能選用任一組字元而不能混用在一起。ANSI SQL 通配符只在使用 Jet 4.X 和 Microsoft OLE DB Provider for Jet 時可用。如果試圖通過 Microsoft Access 或 DAO 來使用 ANSI SQL 通配符,這些字元會被理解為普通字元。反之,當使用 Microsoft OLE DB Provider for Jet 和 Jet 4.X 時只能使用 ANSI SQL 通配符。 匹配的字元 Microsoft Jet SQL ANSI SQL
任意單個字元 ? _ (下劃線)
零或多個字元 * %
Microsoft Jet SQL 語法通常上不是很嚴格。比如,允許對表達式分組和排序。
Microsoft Jet SQL 支持更強大的表達式。
Microsoft Jet SQL 提供下列擴展的性能
TRANSFORM 語句,可以用來創建 crosstab 查詢。
額外的 SQL 聚合函數,比如 StDev 和 VarP。
PARAMETERS 聲明用來定義參數查詢。
Microsoft Jet SQL 不支持下列 ANSI SQL 性能:
DISTINCT 聚合函數保留字。比如,Microsoft Jet SQL 不允許 SUM(DISTINCT columnname)。
LIMIT TO nn ROWS 子句,用來限制查詢返回的行數。我們只能用 WHERE 子句來限制查詢的范圍。
⑶ 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.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 ProctName ,UnitPrice ,UnitsInStock ,UnitPrice*UnitsInStock AS valueInStock
FROM Procts
二 .WHERE 子句指定查詢條件
二 . 1比較運算符
比較運算符 含義
= 等於
> 大於
= 大於等於
不等於
!> 不大於
!#1/1/96# AND OrderDate#96-1-1#
也可以表示為:
WHERE OrderDate>Datevalue(『1/1/96』)
使用 NOT 表達式求反。
例:查看96年1月1日以後的定單
WHERE Not OrderDateQuantity
另一種方法是用 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
(table2 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 [LEFT|RIGHT]JOIN table2
ON table1.field1comparision table.field2
用左連接來建立外部連接,在表達式的左邊的表會顯示其所有的數據
例:不管有沒有定貨量,返回所有商品
SELECT ProctName ,OrderID
FROM Procts
LEFT JOIN Orders ON Procts.PrctsID=Orders.ProctID
右連接與左連接的差別在於:不管左側表裡有沒有匹配的記錄,它都從左側表中返回所有記錄。
例:如果想了解客戶的信息,並統計各個地區的客戶分布,這時可以用一個右連接,即使某個地區沒有客戶,也要返回客戶信息。
空值不會相互匹配,可以通過外連接才能測試被連接的某個表的欄位是否有空值。
SELECT *
FROM talbe1
LEFT JOIN table2 ON table1.a=table2.c
四 .1 連接查詢中使用Iif函數實現以0值顯示空值
Iif表達式: Iif(IsNull(Amount,0,Amout)
例:無論定貨大於或小於¥50,都要返回一個標志。
Iif([Amount]>50,?Big order?,?Small order?)
五 分組和總結查詢結果
在SQL的語法里,GROUP BY和HAVING子句用來對數據進行匯總。GROUP BY子句指明了按照哪幾個欄位來分組,而將記錄分組後,用HAVING子句過濾這些記錄。
GROUP BY 子句的語法
SELECT fidldlist
FROM table
WHERE criteria
[GROUP BY groupfieldlist [HAVING groupcriteria]]
註:Microsoft Jet資料庫 Jet 不能對備注或OLE對象欄位分組。
GROUP BY欄位中的Null值以備分組但是不能被省略。
在任何SQL合計函數中不計算Null值。
GROUP BY子句後最多可以帶有十個欄位,排序優先順序按從左到右的順序排列。
例:在『WA』地區的雇員表中按頭銜分組後,找出具有同等頭銜的雇員數目大於1人的所有頭銜。
SELECT Title ,Count(Title) as Total
FROM Employees
WHERE Region = 『WA』
GROUP BY Title
HAVING Count(Title)>1
JET SQL 中的聚積函數
聚集函數 意義
SUM ( ) 求和
AVG ( ) 平均值
COUNT ( ) 表達式中記錄的數目
COUNT (* ) 計算記錄的數目
MAX 最大值
MIN 最小值
VAR 方差
STDEV 標准誤差
FIRST 第一個值
LAST 最後一個值
六 用Parameters聲明創建參數查詢
Parameters聲明的語法:
PARAMETERS name datatype[,name datatype[, …]]
其中name 是參數的標志符,可以通過標志符引用參數.
Datatype說明參數的數據類型.
使用時要把PARAMETERS 聲明置於任何其他語句之前.
例:
PARAMETERS[Low price] Currency,[Beginning date]datatime
SELECT OrderID ,OrderAmount
FROM Orders
WHERE OrderAMount>[low price]
AND OrderDate>=[Beginning date]
七 功能查詢
所謂功能查詢,實際上是一種操作查詢,它可以對資料庫進行快速高效的操作.它以選擇查詢為目的,挑選出符合條件的數據,再對數據進行批處理.功能查詢包括更新查詢,刪除查詢,添加查詢,和生成表查詢.
七 .1 更新查詢
UPDATE子句可以同時更改一個或多個表中的數據.它也可以同時更改多個欄位的值.
更新查詢語法:
UPDATE 表名
SET 新值
WHERE 准則
例:英國客戶的定貨量增加5%,貨運量增加3%
UPDATE OEDERS
SET OrderAmount = OrderAmount *1.1
Freight = Freight*1.03
WHERE ShipCountry = 『UK』
七 .2 刪除查詢
DELETE子句可以使用戶刪除大量的過時的或冗於的數據.
注:刪除查詢的對象是整個記錄.
DELETE子句的語法:
DELETE [表名.*]
FROM 來源表
WHERE 准則
例: 要刪除所有94年前的定單
DELETE *
FROM Orders
WHERE OrderData,,=)一起使用.返回一個布爾值True或False.ANY的意思是,表達式與子查詢返回的一系列的值逐一比較,只要其中的一次比較產生True結果,ANY測試的返回 True值(既WHERE子句的結果),對應於該表達式的當前記錄將進入主查詢的結果中.ALL測試則要求表達式與子查詢返回的一系列的值的比較都產生True結果,才回返回True值.
例:主查詢返回單價比任何一個折扣大於等於25%的產品的單價要高的所有產品
SELECT * FROM Procts
WHERE UnitPrice>ANY
(SELECT UnitPrice FROM[Order Details] WHERE Discount>0.25)
十 .2檢查表達式的值是否匹配子查詢返回的一組值的某個值
語法:
[NOT]IN(子查詢)
例:返回庫存價值大於等於1000的產品.
SELECT ProctName FROM Procts
WHERE ProctID IN
(SELECT PrdoctID FROM [Order DEtails]
WHERE UnitPrice*Quantity>= 1000)
十 .2檢測子查詢是否返回任何記錄
語法:
[NOT]EXISTS (子查詢)
例:用EXISTS檢索英國的客戶
SELECT ComPanyName,ContactName
FROM Orders
WHERE EXISTS
(SELECT *
FROM Customers
WHERE Country = 『UK』 AND
Customers.CustomerID= Orders.CustomerID)
⑷ [SQL快速入門-03] 常用關系型資料庫匯總
本文將為您梳理關系型資料庫的幾種常見選擇,包括它們的歷史、特性和適用場景。以下是四種常用的RDBMS:MySQL、SQL Server、Oracle以及Access的簡要介紹。
1. MySQL
MySQL,源自開源,由MySQL AB公司開發,適合中小型網站,支持多線程和多用戶,以快速著稱。它在Windows、Linux等平台上運行,有免費版和收費版,功能和用途根據商業或非商業用途有所區分。SQL發音為「sessel」,而MySQL發音為「my ess-que-ell」。
2. SQL Server
微軟的SQL Server專為Windows設計,不僅支持標准SQL,還提供增強版的T-SQL。它在企業級應用中有廣泛應用,但局限於Windows環境。
3. Oracle
Oracle是一個強大的多用戶資料庫,以高並發和高吞吐量而知名,適用於B/S或C/S模式,支持多種操作系統。作為最老的資料庫之一,Oracle的歷史可以追溯到1977年,至今仍是最受信賴的選擇之一。
4. Access
Access是Microsoft的入門級資料庫,隨Office專業版提供,適合小型項目,價格便宜且易於操作,使用Jet資料庫引擎,擁有簡化版的SQL(Jet SQL)特性,無需專業知識。