SQL中一些小巧但常用的關鍵字小結
前言
前面的幾篇文章中,我們大體上介紹了 SQL 中基本的創(chuàng)建、查詢語句,甚至也學習了相對復雜的連接查詢和子查詢,這些基本功相信你也一定掌握的不錯,那么本篇則著重介紹幾個技巧方面的關鍵字,能夠讓你更快更有效率的寫出一些 SQL。
下面話不多說了,來一起看看詳細的介紹吧
起別名
在實際的項目中,有時候我們的表名、字段名過于復雜以致于我們的 SQL 寫出來過長、過于復雜,這時候我們往往會通過起別名的方式將一些名字較長、較為復雜的字段或是表名簡化。
我們可以使用別名(Alias)來對數(shù)據表或者列進行臨時命名,既然是別名,也就是說并不會修改原表或列的原始名稱,僅僅用于當前查詢的簡介化顯示。
給表起別名:
select * from person as p where p.id = 1;
一旦為表執(zhí)行了別名,那么本次查詢的子查詢語句中都可以直接引用別名替代原表的引用。
給列起別名:
select name as n,age as a from perosn;
除了使用關鍵字 as 來給表或是列起別名外,還可以直接使用空格字符達到同樣的效果,但是個人認為要么全部使用 as 進行別名,要么全部使用空格進行別名,不要交叉使用使得你的 SQL 復雜又難以看懂。
消除重復記錄
有時候,我們的數(shù)據庫中會存在兩條完全一樣的數(shù)據,我們也叫做冗余數(shù)據,當然不希望在查詢數(shù)據的時候查出來這么些冗余的重復數(shù)據,我們要把它們過濾掉。
LeetCode 上的一道簡單題:
有一個courses 表 ,有: student (學生) 和 class (課程)。
請列出所有超過或等于5名學生的課。
例如,表:
+---------+------------+ | student | class | +---------+------------+ | A | Math | | B | English | | C | Math | | D | Biology | | E | Math | | F | Computer | | G | Math | | H | Math | | I | Math | +---------+------------+
應該輸出:
+---------+
| class |
+---------+
| Math |
+---------+
你可以花個一分鐘思考一下,運用我們之前的基本功,應該是不難的。
顯然是需要用到分組的,想要統(tǒng)計每門課有多少人選,就得按照學科進行分組,每個分組內就是該門學科選修的學生記錄。
那么 SQL 語句也就信手拈來了:
select class from courses group by class having count(student) >=5
但是你提交后在海量測試用例下,會返回給你解答錯誤的提示,不信你試試,問題出在哪?
問題就出現(xiàn)在冗余數(shù)據這個邊界條件沒有被考慮,如果 A 選了兩次 Math,當我們對 Math 這個分組進行計數(shù)時就會多算一次選 Math 的人數(shù),實際上這是不符合邏輯的,我們需要過濾掉那些重復選擇的數(shù)據記錄。
解決方案如下:
select class from courses group by class having count(distinct student) >=5
有些人可能看出來了,我們在 count 函數(shù)的列參數(shù)前添加了一個 distinct 關鍵字,它表示如果 student 列的值重復出現(xiàn)的話只計數(shù)一次。
當然,distinct 除了可以在聚合函數(shù)中使用外,也可以直接用在查詢語句的列篩選階段,例如:
//取出所有的學生,不允許重復名字的學生同時出現(xiàn) select distinct name from students
連接結果集
UNION 運算符可以將一個或多個 SELECT 語句的結果連接組合成一個結果集,但要求兩個或多個結果具有相同數(shù)量的列,列的數(shù)據類型相同,舉個例子:
構建一個學生表:
+----+------+----------+-------+ | id | name | uNo | fees | +----+------+----------+-------+ | 1 | 張三 | 15263501 | 18000 | | 2 | 李四 | 15263506 | 15960 | | 3 | 王二 | 15263512 | 2500 | +----+------+----------+-------+
學生表主要有學生的姓名,學號和學費。
構建一個教師表:
+----+--------+------+--------+ | id | name | tNo | salary | +----+--------+------+--------+ | 1 | 李老師 | 1001 | 10000 | | 2 | 楊老師 | 1002 | 15000 | | 3 | 曹老師 | 1030 | 5000 | +----+--------+------+--------+
現(xiàn)在有一個需求,需要拿到全校所有人的姓名和編號,包括學生和老師。一般來說,我們兩次 select 查詢就好了,但是沒法合并在一個結果集中顯示,這是一個問題。
于是我們可以使用 union 來連接兩個結果并在一張表中顯示出來:
select name,uNo from students union select name,tNo from teacher
查詢結果:
+--------+----------+
| name | uNo |
+--------+----------+
| 張三 | 15263501 |
| 李四 | 15263506 |
| 王二 | 15263512 |
| 李老師 | 1001 |
| 楊老師 | 1002 |
| 曹老師 | 1030 |
+--------+----------+
看起來是不是直觀了很多,除此之外的是,如果兩個結果集中存在完全重復的數(shù)據記錄,合并后的結果集中不會重復出現(xiàn)該數(shù)據記錄。
當然了,如果你不需要在合并結果集的時候刪除掉重復的數(shù)據行,你可以轉而使用關鍵字 UNION ALL 替代 UNION。
TOP
TOP 子句用于從一張數(shù)據表中取回前 N 個或者 X% 的記錄,但是需要注意的是,沒有一個數(shù)據庫實現(xiàn)是支持 TOP 的,各自有各自的關鍵字作為替代,例如 MySQL 和 SQLserver 使用 LIMIT 關鍵字,Oracle 使用 ROWNUM 關鍵字。
例如:
select * from students limit 2;
MySQL 數(shù)據庫取出前兩條數(shù)據,等效的 Oracle 數(shù)據庫寫法:
select * from students rownum <= 2
以上的一些關鍵字雖然逐個看起來很簡單,但有時候可能會幫上你大忙的,不要忘記使用它們!。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
使用SQL語句查詢MySQL,SQLServer,Oracle所有數(shù)據庫名和表名,字段名
本文例出了使用SQL語句查詢MySQL,SQLServer,Oracle所有數(shù)據庫名和表名的SQL語句,有需要的可以參考下2018-03-03JDBC大批量寫入數(shù)據到SQLServer2000,記錄數(shù)大于10000
JDBC大批量寫入數(shù)據到SQLServer2000,記錄數(shù)大于100002009-12-12Doris?數(shù)據模型ROLLUP及前綴索引官方教程
本文檔主要從邏輯層面,描述 Doris 的數(shù)據模型 ROLLUP 以及前綴索引的概念,以幫助用戶更好的使用 Doris 應對不同的業(yè)務場景,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05DataGrip 數(shù)據導出與導入的實現(xiàn)示例
DataGrip 是一款類似于Workbench的數(shù)據庫設計工具。文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09