主頁 > 知識庫 > SQL中一些小巧但常用的關(guān)鍵字小結(jié)

SQL中一些小巧但常用的關(guān)鍵字小結(jié)

熱門標(biāo)簽:簡單的智能語音電銷機器人 小程序智能電話機器人 南昌呼叫中心外呼系統(tǒng)哪家好 ai電話電話機器人 怎么申請400熱線電話 泗洪正規(guī)電話機器人找哪家 河北便宜電銷機器人軟件 湖南保險智能外呼系統(tǒng)產(chǎn)品介紹 怎么去開發(fā)一個電銷機器人

前言

前面的幾篇文章中,我們大體上介紹了 SQL 中基本的創(chuàng)建、查詢語句,甚至也學(xué)習(xí)了相對復(fù)雜的連接查詢和子查詢,這些基本功相信你也一定掌握的不錯,那么本篇則著重介紹幾個技巧方面的關(guān)鍵字,能夠讓你更快更有效率的寫出一些 SQL。

下面話不多說了,來一起看看詳細的介紹吧

起別名

在實際的項目中,有時候我們的表名、字段名過于復(fù)雜以致于我們的 SQL 寫出來過長、過于復(fù)雜,這時候我們往往會通過起別名的方式將一些名字較長、較為復(fù)雜的字段或是表名簡化。

我們可以使用別名(Alias)來對數(shù)據(jù)表或者列進行臨時命名,既然是別名,也就是說并不會修改原表或列的原始名稱,僅僅用于當(dāng)前查詢的簡介化顯示。

給表起別名:

select * from person as p
where p.id = 1;

一旦為表執(zhí)行了別名,那么本次查詢的子查詢語句中都可以直接引用別名替代原表的引用。

給列起別名:

select name as n,age as a from perosn;

除了使用關(guān)鍵字 as 來給表或是列起別名外,還可以直接使用空格字符達到同樣的效果,但是個人認為要么全部使用 as 進行別名,要么全部使用空格進行別名,不要交叉使用使得你的 SQL 復(fù)雜又難以看懂。

消除重復(fù)記錄

有時候,我們的數(shù)據(jù)庫中會存在兩條完全一樣的數(shù)據(jù),我們也叫做冗余數(shù)據(jù),當(dāng)然不希望在查詢數(shù)據(jù)的時候查出來這么些冗余的重復(fù)數(shù)據(jù),我們要把它們過濾掉。

LeetCode 上的一道簡單題:

有一個courses 表 ,有: student (學(xué)生) 和 class (課程)。

請列出所有超過或等于5名學(xué)生的課。

例如,表:

+---------+------------+
| student | class  |
+---------+------------+
| A  | Math  |
| B  | English |
| C  | Math  |
| D  | Biology |
| E  | Math  |
| F  | Computer |
| G  | Math  |
| H  | Math  |
| I  | Math  |
+---------+------------+

應(yīng)該輸出:

+---------+
| class   |
+---------+
| Math    |
+---------+

你可以花個一分鐘思考一下,運用我們之前的基本功,應(yīng)該是不難的。

顯然是需要用到分組的,想要統(tǒng)計每門課有多少人選,就得按照學(xué)科進行分組,每個分組內(nèi)就是該門學(xué)科選修的學(xué)生記錄。

那么 SQL 語句也就信手拈來了:

select class from courses
group by class
having count(student) >=5 

但是你提交后在海量測試用例下,會返回給你解答錯誤的提示,不信你試試,問題出在哪?

問題就出現(xiàn)在冗余數(shù)據(jù)這個邊界條件沒有被考慮,如果 A 選了兩次 Math,當(dāng)我們對 Math 這個分組進行計數(shù)時就會多算一次選 Math 的人數(shù),實際上這是不符合邏輯的,我們需要過濾掉那些重復(fù)選擇的數(shù)據(jù)記錄。

解決方案如下:

select class from courses
group by class
having count(distinct student) >=5 

有些人可能看出來了,我們在 count 函數(shù)的列參數(shù)前添加了一個 distinct 關(guān)鍵字,它表示如果 student 列的值重復(fù)出現(xiàn)的話只計數(shù)一次。

當(dāng)然,distinct 除了可以在聚合函數(shù)中使用外,也可以直接用在查詢語句的列篩選階段,例如:

//取出所有的學(xué)生,不允許重復(fù)名字的學(xué)生同時出現(xiàn)
select distinct name from students

連接結(jié)果集

UNION 運算符可以將一個或多個 SELECT 語句的結(jié)果連接組合成一個結(jié)果集,但要求兩個或多個結(jié)果具有相同數(shù)量的列,列的數(shù)據(jù)類型相同,舉個例子:

構(gòu)建一個學(xué)生表:

+----+------+----------+-------+
| id | name | uNo  | fees |
+----+------+----------+-------+
| 1 | 張三 | 15263501 | 18000 |
| 2 | 李四 | 15263506 | 15960 |
| 3 | 王二 | 15263512 | 2500 |
+----+------+----------+-------+

學(xué)生表主要有學(xué)生的姓名,學(xué)號和學(xué)費。

構(gòu)建一個教師表:

+----+--------+------+--------+
| id | name | tNo | salary |
+----+--------+------+--------+
| 1 | 李老師 | 1001 | 10000 |
| 2 | 楊老師 | 1002 | 15000 |
| 3 | 曹老師 | 1030 | 5000 |
+----+--------+------+--------+

現(xiàn)在有一個需求,需要拿到全校所有人的姓名和編號,包括學(xué)生和老師。一般來說,我們兩次 select 查詢就好了,但是沒法合并在一個結(jié)果集中顯示,這是一個問題。

于是我們可以使用 union 來連接兩個結(jié)果并在一張表中顯示出來:

select name,uNo from students
union
select name,tNo from teacher

查詢結(jié)果:

+--------+----------+
| name   | uNo      |
+--------+----------+
| 張三   | 15263501 |
| 李四   | 15263506 |
| 王二   | 15263512 |
| 李老師 | 1001     |
| 楊老師 | 1002     |
| 曹老師 | 1030     |
+--------+----------+

看起來是不是直觀了很多,除此之外的是,如果兩個結(jié)果集中存在完全重復(fù)的數(shù)據(jù)記錄,合并后的結(jié)果集中不會重復(fù)出現(xiàn)該數(shù)據(jù)記錄。

當(dāng)然了,如果你不需要在合并結(jié)果集的時候刪除掉重復(fù)的數(shù)據(jù)行,你可以轉(zhuǎn)而使用關(guān)鍵字 UNION ALL 替代 UNION。

TOP

TOP 子句用于從一張數(shù)據(jù)表中取回前 N 個或者 X% 的記錄,但是需要注意的是,沒有一個數(shù)據(jù)庫實現(xiàn)是支持 TOP 的,各自有各自的關(guān)鍵字作為替代,例如 MySQL 和 SQLserver 使用 LIMIT 關(guān)鍵字,Oracle 使用 ROWNUM 關(guān)鍵字。

例如:

select * from students limit 2;

MySQL 數(shù)據(jù)庫取出前兩條數(shù)據(jù),等效的 Oracle 數(shù)據(jù)庫寫法:

select * from students
rownum = 2

以上的一些關(guān)鍵字雖然逐個看起來很簡單,但有時候可能會幫上你大忙的,不要忘記使用它們!。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • SQL語句的各個關(guān)鍵字的解析過程詳細總結(jié)
  • sql連接查詢中,where關(guān)鍵字的位置講解
  • sql中的left join及on、where條件關(guān)鍵字的區(qū)別詳解
  • Mysql帶And關(guān)鍵字的多條件查詢語句
  • MySQL單表多關(guān)鍵字模糊查詢的實現(xiàn)方法
  • MySQL 5.7中的關(guān)鍵字與保留字詳解
  • sql server關(guān)鍵字詳解大全(圖文)

標(biāo)簽:柳州 荊門 景德鎮(zhèn) 淮安 瀘州 威海 江蘇 那曲

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL中一些小巧但常用的關(guān)鍵字小結(jié)》,本文關(guān)鍵詞  SQL,中,一些,小巧,但,常用的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL中一些小巧但常用的關(guān)鍵字小結(jié)》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL中一些小巧但常用的關(guān)鍵字小結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章