通用SQL資料庫查詢語句精華使用簡介

2020-12-12 站長之家

一、 簡單查詢
  
簡單的Transact-SQL查詢只包括選擇列表、FROM子句和WHERE子句。它們分別說明所查詢列、查詢的表或視圖、以及搜索條件等。
  
例如,下面的語句查詢testtable表中姓名為「張三」的nickname欄位和email欄位。
  
SELECT nickname,email
FROM testtable
WHERE name='張三'
  
(一) 選擇列表
  
選擇列表(select_list)指出所查詢列,它可以是一組列名列表、星號、表達式、變量(包括局部變量和全局變量)等構成。
  
1、選擇所有列
  
例如,下面語句顯示testtable表中所有列的數據:
  
SELECT *
FROM testtable
2、選擇部分列並指定它們的顯示次序
  
查詢結果集合中數據的排列順序與選擇列表中所指定的列名排列順序相同。
  
例如:
  
SELECT nickname,email
FROM testtable
3、更改列標題
  
在選擇列表中,可重新指定列標題。定義格式為:
  
列標題=列名
列名 列標題
  
如果指定的列標題不是標準的標識符格式時,應使用引號定界符,例如,下列語句使用漢字顯示列標題:
  
SELECT 暱稱=nickname,電子郵件=email
FROM testtable
  
4、刪除重複行
  
SELECT語句中使用ALL或DISTINCT選項來顯示錶中符合條件的所有行或刪除其中重複的數據行,默認為ALL。使用DISTINCT選項時,對於所有重複的數據行在SELECT返回的結果集合中只保留一行。
  
5、限制返回的行數
  
使用TOP n [PERCENT]選項限制返回的數據行數,TOP n說明返回n行,而TOP n PERCENT時,說明n是表示一百分數,指定返回的行數等於總行數的百分之幾。
  
例如:
  
SELECT TOP 2 *FROM testtable SELECT TOP 20 PERCENT * FROM testtable
  
(二)FROM子句
  
FROM子句指定SELECT語句查詢及與查詢相關的表或視圖。在FROM子句中最多可指定256個表或視圖,它們之間用逗號分隔。
  
在FROM子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列所屬的表或視圖。例如在usertable和citytable表中同時存在cityid列,在查詢兩個表中的cityid時應使用下面語句格式加以限定:
  
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在FROM子句中可用以下兩種格式為表或視圖指定別名:
  
表名 as 別名
表名 別名
  
(二) FROM子句
  
FROM子句指定SELECT語句查詢及與查詢相關的表或視圖。在FROM子句中最多可指定256個表或視圖,它們之間用逗號分隔。
  
在FROM子句同時指定多個表或視圖時,如果選擇列表中存在同名列,這時應使用對象名限定這些列所屬的表或視圖。例如在usertable和citytable表中同時存在cityid列,在查詢兩個表中的cityid時應使用下面語句格式加以限定:
  
SELECT username,citytable.cityid
FROM usertable,citytable
WHERE usertable.cityid=citytable.cityid
在FROM子句中可用以下兩種格式為表或視圖指定別名:
  
表名 as 別名
表名 別名
  
例如上面語句可用表的別名格式表示為:
  
SELECT username,b.cityid
FROM usertable a,citytable b
WHERE a.cityid=b.cityid
SELECT不僅能從表或視圖中檢索數據,它還能夠從其它查詢語句所返回的結果集合中查詢數據。
  
例如:
  
SELECT a.au_fname+a.au_lname
FROM authors a,titleauthor ta
(SELECT title_id,title
FROM titles
WHERE ytd_sales>10000
) AS t
WHERE a.au_id=ta.au_id
AND ta.title_id=t.title_id
此例中,將SELECT返回的結果集合給予一別名t,然後再從中檢索數據。
  
(三) 使用WHERE子句設置查詢條件
  
WHERE子句設置查詢條件,過濾掉不需要的數據行。例如下面語句查詢年齡大於20的數據:
  
SELECT *
FROM usertable
WHERE age>20
WHERE子句可包括各種條件運算符:
  
比較運算符(大小比較):>、>=、=、<、<=、<>、!>、!<
範圍運算符(表達式值是否在指定的範圍):BETWEEN…AND…
NOT BETWEEN…AND…
列表運算符(判斷表達式是否為列表中的指定項):IN (項1,項2……)
NOT IN (項1,項2……)
模式匹配符(判斷值是否與指定的字符通配格式相符):LIKE、NOT LIKE
空值判斷符(判斷表達式是否為空):IS NULL、NOT IS NULL
邏輯運算符(用於多條件的邏輯連接):NOT、AND、OR
  
1、範圍運算符例:age BETWEEN 10 AND 30相當於age>=10 AND age<=30
  
2、列表運算符例:country IN ('Germany','China')
  
3、模式匹配符例:常用於模糊查找,它判斷列值是否與指定的字符串格式相匹配。可用於char、varchar、text、ntext、datetime和smalldatetime等類型查詢。
  
可使用以下通配字符:
  
百分號%:可匹配任意類型和長度的字符,如果是中文,請使用兩個百分號即%%。
  
下劃線_:匹配單個任意字符,它常用來限制表達式的字符長度。
  
方括號[]:指定一個字符、字符串或範圍,要求所匹配對象為它們中的任一個。[^]:其取值也[] 相同,但它要求所匹配對象為指定字符以外的任一個字符。
  
例如:
  
限制以Publishing結尾,使用LIKE '%Publishing'
  
限制以A開頭:LIKE '[A]%'
  
限制以A開頭外:LIKE '[^A]%'
  
4、空值判斷符例WHERE age IS NULL
  
5、邏輯運算符:優先級為NOT、AND、OR
  
(四)查詢結果排序
  
使用ORDER BY子句對查詢返回的結果按一列或多列排序。ORDER BY子句的語法格式為:
  
ORDER BY {column_name [ASC|DESC]} [,…n]
  
其中ASC表示升序,為默認值,DESC為降序。ORDER BY不能按ntext、text和image數據類型進行排序。
  
例如:
  
SELECT *
FROM usertable
ORDER BY age desc,userid ASC
另外,可以根據表達式進行排序。
  
二、 聯合查詢
  
UNION運算符可以將兩個或兩個以上上SELECT語句的查詢結果集合合併成一個結果集合顯示,即執行聯合查詢。UNION的語法格式為:
  
select_statement
UNION [ALL] selectstatement
[UNION [ALL] selectstatement][…n]
其中selectstatement為待聯合的SELECT查詢語句。
  
ALL選項表示將所有行合併到結果集合中。不指定該項時,被聯合查詢結果集合中的重複行將只保留一行。
  
聯合查詢時,查詢結果的列標題為第一個查詢語句的列標題。因此,要定義列標題必須在第一個查詢語句中定義。要對聯合查詢結果排序時,也必須使用第一查詢語句中的列名、列標題或者列序號。
  
在使用UNION 運算符時,應保證每個聯合查詢語句的選擇列表中有相同數量的表達式,並且每個查詢選擇表達式應具有相同的數據類型,或是可以自動將它們轉換為相同的數據類型。在自動轉換時,對於數值類型,系統將低精度的數據類型轉換為高精度的數據類型。
  
在包括多個查詢的UNION語句中,其執行順序是自左至右,使用括號可以改變這一執行順序。例如:
  
查詢1 UNION (查詢2 UNION 查詢3)
  
三、連接查詢
  
通過連接運算符可以實現多個表查詢。連接是關係資料庫模型的主要特點,也是它區別於其它類型資料庫管理系統的一個標誌。
  
在關係資料庫管理系統中,表建立時各數據之間的關係不必確定,常把一個實體的所有信息存放在一個表中。當檢索數據時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶來很大的靈活性,他們可以在任何時候增加新的數據類型。為不同實體創建新的表,爾後通過連接進行查詢。
  
連接可以在SELECT 語句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出連接時有助於將連接操作與WHERE子句中的搜索條件區分開來。所以,在Transact-SQL中推薦使用這種方法。
  
SQL-92標準所定義的FROM子句的連接語法格式為:
  
FROM join_table join_type join_table
[ON (join_condition)]
其中join_table指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一個表操作的連接又稱做自連接。
  
join_type 指出連接類型,可分為三種:內連接、外連接和交叉連接。內連接(INNER JOIN)使用比較運算符進行表間某(些)列數據的比較操作,並列出這些表中與連接條件相匹配的數據行。根據所使用的比較方式不同,內連接又分為等值連接、自然連接和不等連接三種。外連接分為左外連接(LEFT OUTER JOIN或LEFT JOIN)、右外連接(RIGHT OUTER JOIN或RIGHT JOIN)和全外連接(FULL OUTER JOIN或FULL JOIN)三種。與內連接不同的是,外連接不只列出與連接條件相匹配的行,而是列出左表(左外連接時)、右表(右外連接時)或兩個表(全外連接時)中所有符合搜索條件的數據行。
  
交叉連接(CROSS JOIN)沒有WHERE 子句,它返回連接表中所有數據行的笛卡爾積,其結果集合中的數據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。
  
連接操作中的ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運算符、邏輯運算符等構成。
  
無論哪種連接都不能對text、ntext和image數據類型列進行直接連接,但可以對這三種列進行間接連接。例如:
  
SELECT p1.pub_id,p2.pub_id,p1.pr_info
FROM pub_info AS p1 INNER JOIN pub_info AS p2
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info)
  
(一)內連接
  
內連接查詢操作列出與連接條件匹配的數據行,它使用比較運算符比較被連接列的列值。內連接分三種:
  
1、等值連接:在連接條件中使用等於號(=)運算符比較被連接列的列值,其查詢結果中列出被連接表中的所有列,包括其中的重複列。
  
2、不等連接: 在連接條件使用除等於運算符以外的其它比較運算符比較被連接的列的列值。這些運算符包括>、>=、<=、<、!>、!<和<>。
  
3、自然連接:在連接條件中使用等於(=)運算符比較被連接列的列值,但它使用選擇列表指出查詢結果集合中所包括的列,並刪除連接表中的重複列。

例,下面使用等值連接列出authors和publishers表中位於同一城市的作者和出版社:
  
SELECT *
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
又如使用自然連接,在選擇列表中刪除authors 和publishers 表中重複列(city和state):
  
SELECT a.*,p.pub_id,p.pub_name,p.country
FROM authors AS a INNER JOIN publishers AS p
ON a.city=p.city
  
(二)外連接
  
內連接時,返回查詢結果集合中的僅是符合查詢條件( WHERE 搜索條件或 HAVING 條件)和連接條件的行。而採用外連接時,它返回到查詢結果集合中的不僅包含符合連接條件的行,而且還包括左表(左外連接時)、右表(右外連接時)或兩個邊接表(全外連接)中的所有數據行。如下面使用左外連接將論壇內容和作者信息連接起來:
  
SELECT a.*,b.* FROM luntan LEFT JOIN usertable as b
ON a.username=b.username
  
下面使用全外連接將city表中的所有作者以及user表中的所有作者,以及他們所在的城市:
  
SELECT a.*,b.*
FROM city as a FULL OUTER JOIN user as b
ON a.username=b.username
  
(三)交叉連接
  
交叉連接不帶WHERE 子句,它返回被連接的兩個表所有數據行的笛卡爾積,返回到結果集合中的數據行數等於第一個表中符合查詢條件的數據行數乘以第二個表中符合查詢條件的數據行數。例,titles表中有6類圖書,而publishers表中有8家出版社,則下列交叉連接檢索到的記錄數將等
  
於6*8=48行。
  
SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY type

相關焦點

  • 資料庫之SQL查詢語句
    、檢索及維護所使用的標準語言,可以用來查詢數據、操縱數據、定義數據、控制數據。所有資料庫都使用相同或者相似的語言。(1) 數據定義語言(DDL ): Data Definition Language用於建立、修改、刪除資料庫對象。資料庫對象包括:表、視圖、索引、序列。
  • SQL 資料庫語句
    當 ALL 隨 EXCEPT 一起使用時 (EXCEPT ALL),不消除重複行。C:INTERSECT 運算符INTERSECT運算符通過只包括 TABLE1 和 TABLE2 中都有的行並消除所有重複行而派生出一個結果表。當 ALL隨 INTERSECT 一起使用時 (INTERSECT ALL),不消除重複行。 註:使用運算詞的幾個查詢結果行必須是一致的。
  • 資料庫常用的sql語句匯總(2)
    show create database db1;創建資料庫指定字符集 create database db1 character set utf8/gbk刪除資料庫 drop database db1;使用資料庫 use db1;
  • 資料庫sql語句的基礎使用,學習資料庫的關鍵一步
    創建資料庫create database 資料庫名;create database 資料庫名 character set 字符集;查看某個資料庫的定義的信息:show create database 資料庫名;刪除資料庫drop database 資料庫名稱;切換資料庫:use
  • 在 Linux 上用 SQL 語句查詢 Apache 日誌
    這次,我們會通過另類的途徑來分析 Apache access 日誌,我們使用的工具是 asql。asql 是一個開源的工具,它能夠允許使用者使用 SQL 語句來查詢日誌,從而通過更加友好的格式展現相同的信息。
  • 請確保你查詢mysql資料庫時,sql語句沒有這麼寫
    資料庫索引,可以讓查詢sql語句效率更高。所以大家在寫查詢的sql語句時為了讓語句執行效率高會讓語句能命中索引,或者新建合適的索引。可是,有時候大家會遇到像下面說的這樣的情況。明明我sql語句where條件的欄位是符合索引,應該可以命中索引的,但是執行時卻沒有命中索引。為什麼會這樣呢,是人性的……額,串臺了,調回來。要說明這個問題,大家先來比較一下下面的這兩個sql語句。
  • 優化SQL查詢:如何寫出高性能SQL語句
    執行計劃是資料庫根據SQL語句和相關表的統計信息作出的一個查詢方案,這個方案是由查詢優化器自動分析產生的,比如一條SQL語句如果用來從一個 10萬條記錄的表中查1條記錄,那查詢優化器會選擇「索引查找」方式,如果該表進行了歸檔,當前只剩下5000條記錄了,那查詢優化器就會改變方案,採用 「全表掃描」方式。
  • 【資料庫】MySQL常見SQL語句
    -databasename - 資料庫名DROP DATABASE databasename;8、修改資料庫名alter database 舊名稱 modify name = 新名稱9、備份sql server
  • 使用Python操作SQL Server資料庫
    先說一下SQL Server如果有條件可以使用遠程連接或者TeamViewer等工具,操作帶GUI的資料庫管理器,實施起來可以很省心。可以直接查看結果,模板化查詢甚至提示語句錯誤等。如果是使用linux本地或者ssh訪問SQL Server資料庫的,稍微麻煩點。可以使用sqlcmd作為替代工具。後面會介紹。
  • 提升SQL語句性能的方法
    用具體案例進行SQL語句性能提升的方法。先用實際案例分析了優化SQL語句的方法,然後再結合nat123這個實際案例分析了如何實現外網訪問內網Mysql資料庫的方法。線上mysql資料庫爆出一個慢查詢,DBA觀察發現,查詢時伺服器IO飆升,IO佔用率達到100%, 執行時間長達7s左右。優化方法:優化的總體思路是拆分sql,將排序操作和查詢所有信息的操作分開。
  • 常用的sql語句集合(適合資料庫初級人員)
    2、刪除資料庫drop database dbname3、備份sql server--- 創建備份數據的 deviceUSE masterEXEC sp_addumpdevice 'disk', 'testBack
  • Access中查詢SQL資料庫中文字符的問題處理
    用access連結sql server中的表,建立選擇查詢時,無法查找中文數據,在這裡採用了傳遞查詢來解決這個問題。
  • 資料庫sql語句 (提升篇)
    (具體數據使用絕對路徑) (Access可用)insert into b(a, b, c) select d,e,f from b in 『具體資料庫』 where 條件例子:..from b in '"&Server.MapPath(".")
  • SQL查詢語句精華使用簡要
    一、 簡單查詢簡單的Transact-SQL查詢只包括選擇列表、FROM子句和WHERE子句。它們分別說明所查詢列、查詢的表或視圖、以及搜索條件等。例如,下面的語句查詢testtable表中姓名為「張三」的nickname欄位和email欄位。
  • Mysql中一條SQL查詢語句是如何執行的?
    2.查詢流程解析select * from table1 where ID=10;這條語句相信大家再熟悉不過了,下面我們就看看這一條語句在mysql中是怎麼執行的。第一步:一條sql語句要經過連接器,客戶端要和mysql建立連接。
  • Java資料庫連接性簡介
    JDBC(Java資料庫連接性)是Java API,用於管理與資料庫的連接,發出查詢和命令以及處理從資料庫獲得的結果集。JDBC在1997年作為JDK 1.1的一部分發布,是為Java持久層開發的首批組件之一。
  • NET開發-在SQL Server資料庫中使用SQL語句實現多表之間嵌套查詢...
    Server中,多表之間的查詢需要連接在一起,然後再使用嵌套,將多個SQL語句嵌套起來,實現複雜的嵌套查詢。如下是使用帶in查詢的SQL語句:select * f rom BW_Student where Age in (23,24,25,21)
  • 「MySQL系列」分析Sql執行時間及查詢執行計劃(附資料庫和一千萬數據)
    我們幹開發面試工作的時候,發現對資料庫的面試比重很大。說明對資料庫的知識掌握對我們程式設計師越來越重要了。接下來這篇文章我們來看看如何分析我們的sql執行效率。首先找到執行慢的sql,然後對執行慢的SQL進行分析。
  • SQL查詢語句場景應用
    而SQL非常值得愛好者擁有,首先就是它的實用性很強,當學會SQL之後,就會將資料庫的數據牢牢的攥在手裡,任你想怎麼查詢就怎麼查詢,而SQl與其他程式語言結合使用的時候,SQL也是非常重要的組成部分。當SQL熟練時,已經可以掌控數據,至於數據結構的整理和數據渲染可以由其他程式語言來完成。
  • MySQL資料庫SQL優化教程二
    所有SQL語句接受集合作為輸入。返回集合作為輸出。SQL的集合特性允許一條SQL語句的結果作為另一條SQL語句的輸入。SQL 不要求用戶指定對數據的存放方法。這種特性使用戶更易集中精力於要得到的結果。所有SQL語句都使用查詢優化器。它是關係資料庫管理系線(RDBMS)的一部分,由它決定對指定數據最快速度存取的手段。查詢優化器知道存在什麼索引。在哪兒使用合適。