這個(gè)系列是當(dāng)時(shí)參加Datawhale MySQL 第五期的筆記
SQL是什么叫惊?MySQL是什么裆赵?
1.SQL
Structured Query Language(結(jié)構(gòu)化查詢語(yǔ)言)的縮寫(xiě)。它是一種專(zhuān)門(mén)用來(lái)與數(shù)據(jù)庫(kù)溝通的語(yǔ)言嘁字。
2.MySQL
是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),在 WEB 應(yīng)用方面,MySQL是最好的 RDBMS (Relational Database Management System忽洛,關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)) 應(yīng)用軟件。
一环肘、導(dǎo)入數(shù)據(jù)庫(kù)
第二步:將下載的文件解壓縮到文件夾中(這里地址為D:\data\yiibaidb\yiibaidb.sql)
第三步:連接到MySQL服務(wù)器并創(chuàng)建數(shù)據(jù)庫(kù)
1.連接數(shù)據(jù)庫(kù)
找到MySQL Server 8.0\bin
位置欲虚,然后打開(kāi)命令提示符
cd C:\Program Files\MySQL\MySQL Server 8.0\bin
mysql -hlocalhost -uroot -p
2.創(chuàng)建數(shù)據(jù)庫(kù)
mysql> CREATE DATABASE IF NOT EXISTS yiibaidb DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
mysql> use yiibaidb;
3.導(dǎo)入數(shù)據(jù)
mysql> use yiibaidb;
mysql> source D:\data\yiibaidb\yiibaidb.sql
第四步:測(cè)試并導(dǎo)入結(jié)果
mysql> select city,phone,country from `offices`;
二、語(yǔ)句類(lèi)型
本章節(jié)的展示基于Navicat 12.1
(一)查詢語(yǔ)句 SELECT FROM
1.語(yǔ)句解釋
從一個(gè)或多個(gè)表中檢索信息悔雹。
2.通用語(yǔ)法
以下為在MySQL數(shù)據(jù)庫(kù)中查詢數(shù)據(jù)通用的 SELECT 語(yǔ)法:
SELECT column_name,column_name
FROM table_name
[WHERE Clause]
[LIMIT N][ OFFSET M]
- 查詢語(yǔ)句中可以使用一個(gè)或者多個(gè)表复哆,表之間使用逗號(hào)(,)分割,并使用WHERE語(yǔ)句來(lái)設(shè)定查詢條件腌零。
- SELECT 命令可以讀取一條或者多條記錄梯找。
- 可以使用星號(hào)(*)來(lái)代替其他字段,SELECT語(yǔ)句會(huì)返回表的所有字段數(shù)據(jù)
- 可以使用 WHERE 語(yǔ)句來(lái)包含任何條件益涧。
- 可以使用 LIMIT 屬性來(lái)設(shè)定返回的記錄數(shù)锈锤。
- 可以通過(guò)OFFSET指定SELECT語(yǔ)句開(kāi)始查詢的數(shù)據(jù)偏移量。默認(rèn)情況下偏移量為0闲询。
3.操作示例
目標(biāo):查詢 yiibaidb數(shù)據(jù)庫(kù)customers表格的信息
SELECT * FROM customers ;
4.特殊案例
4.1去重語(yǔ)句
(1)定義:在 SELECT 后面加入 DISTINCT 可篩選出不同的(具有唯一性)的值久免。
(2)目標(biāo):查詢yiibaidb數(shù)據(jù)庫(kù)customers表格中city值有哪些
SELECT DISTINCT city FROM customers ;
4.2 限制語(yǔ)句
(1)定義:使用 LIMIT 語(yǔ)句可以限制返回的條數(shù),若同時(shí)使用 OFFSET 會(huì)加入偏移(即從第幾行開(kāi)始揉诹选)妄壶。
需要注意:第一個(gè)被檢索的行是第 0行,而不是第 1行。例如,LIMIT 1 OFFSET 1會(huì)檢索第 2行,而不是第 1行村视。
(2)目標(biāo):從3行開(kāi)始選取yiibaidb數(shù)據(jù)庫(kù)customers表5條數(shù)據(jù)伊磺。
SELECT * FROM customers LIMIT 5 OFFSET 3 ;
4.3 CASE.WHEN.END判斷語(yǔ)句
(1)定義:CASE WHEN END 語(yǔ)法一般用于判斷條件后返回對(duì)應(yīng)的值
(2)分類(lèi):
-- 簡(jiǎn)單函數(shù)
CASE [col_name] WHEN [value1] THEN [result1]…ELSE [default] END
-- 搜索函數(shù)
CASE WHEN [expr] THEN [result1]…ELSE [default] END
需要注意:case函數(shù)只返回第一個(gè)符合條件的值盛正,剩下的case部分將會(huì)被自動(dòng)忽略。
(3)目標(biāo):
對(duì)于簡(jiǎn)單函數(shù)
SELECT *,
CASE country
WHEN 'France' THEN '歐洲'
WHEN 'USA' THEN '美洲'
ELSE '其他'
END '大洲'
FROM customers ;
對(duì)于搜索函數(shù)
(二)篩選語(yǔ)句 WHERE
1.語(yǔ)句解釋
實(shí)現(xiàn)有條件地從表中選取數(shù)據(jù)屑埋,可將 WHERE 子句添加到 SELECT 語(yǔ)句中豪筝。
2.通用語(yǔ)法
SELECT field1, field2,...fieldN FROM table_name1, table_name2...
[WHERE condition1 [AND [OR]] condition2.....
- 查詢語(yǔ)句中你可以使用一個(gè)或者多個(gè)表,表之間使用逗號(hào), 分割摘能,并使用WHERE語(yǔ)句來(lái)設(shè)定查詢條件续崖。
- 可以在 WHERE 子句中指定任何條件。
- 可以使用 AND 或者 OR 指定一個(gè)或多個(gè)條件团搞。
- WHERE 子句也可以運(yùn)用于 SQL 的 DELETE 或者 UPDATE 命令严望。
- WHERE 子句類(lèi)似于程序語(yǔ)言中的 if 條件,根據(jù) MySQL 表中的字段值來(lái)讀取指定的數(shù)據(jù)逻恐。
3.操作符
以下為操作符列表像吻,可用于 WHERE 子句中。
操作示例:
目標(biāo):查找yiibaidb數(shù)據(jù)庫(kù)customers表中符合以下條件數(shù)據(jù):國(guó)別是美國(guó)且creditlimit大于100000
4.通配符
在 SQL 中复隆,通配符與 SQL LIKE 操作符一起使用拨匆。SQL 通配符用于搜索表中的數(shù)據(jù)。
在 SQL 中挽拂,可使用以下通配符:
操作示例:
目標(biāo):查找yiibaidb數(shù)據(jù)庫(kù)customers表中符合以下條件數(shù)據(jù):contactfirstname 是 J 開(kāi)頭
5.運(yùn)算符
MySQL 主要有以下幾種運(yùn)算符:
- 算術(shù)運(yùn)算符
- 比較運(yùn)算符
- 邏輯運(yùn)算符
- 位運(yùn)算符
(1)算術(shù)運(yùn)算符
MySQL 支持的算術(shù)運(yùn)算符包括:
在除法運(yùn)算和模運(yùn)算中惭每,如果除數(shù)為0,將是非法除數(shù)轻局,返回結(jié)果為NULL洪鸭。
(2)比較運(yùn)算符
SELECT 語(yǔ)句中的條件語(yǔ)句經(jīng)常要使用比較運(yùn)算符。通過(guò)這些比較運(yùn)算符仑扑,可以判斷表中的哪些記錄是符合條件的。比較結(jié)果為真置鼻,則返回 1镇饮,為假則返回 0,比較結(jié)果不確定則返回 NULL箕母。
(3)邏輯運(yùn)算符
邏輯運(yùn)算符用來(lái)判斷表達(dá)式的真假储藐。如果表達(dá)式是真,結(jié)果返回 1嘶是。如果表達(dá)式是假钙勃,結(jié)果返回 0。
(4)位運(yùn)算符
位運(yùn)算符是在二進(jìn)制數(shù)上進(jìn)行計(jì)算的運(yùn)算符聂喇。位運(yùn)算會(huì)先將操作數(shù)變成二進(jìn)制數(shù)辖源,進(jìn)行位運(yùn)算蔚携。然后再將計(jì)算結(jié)果從二進(jìn)制數(shù)變回十進(jìn)制數(shù)。
(三)分組語(yǔ)句 GROUP BY
1.語(yǔ)句解釋
GROUP BY 語(yǔ)句根據(jù)一個(gè)或多個(gè)列對(duì)結(jié)果集進(jìn)行分組克饶。在分組的列上我們可以使用 COUNT, SUM, AVG,等函數(shù)酝蜒。
2.通用語(yǔ)法
SELECT column_name, function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name;
3.操作示例
目標(biāo):統(tǒng)計(jì)yiibaidb數(shù)據(jù)庫(kù)customers表中country類(lèi)別數(shù)據(jù)
注意:在分組后的結(jié)果中,不可以使用 WHERE 對(duì)分組結(jié)果進(jìn)行篩選矾湃,只能使用 HAVING 語(yǔ)句
(四)排序語(yǔ)句 ORDER BY
1.語(yǔ)句解釋
對(duì)讀取的數(shù)據(jù)進(jìn)行排序亡脑,此時(shí)可以使用 MySQL 的 ORDER BY 子句來(lái)設(shè)定想按哪個(gè)字段哪種方式來(lái)進(jìn)行排序,再返回搜索結(jié)果邀跃。
2.通用語(yǔ)法
SELECT field1, field2,...fieldN FROM table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
ORDER BY 語(yǔ)句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序霉咨。ORDER BY 語(yǔ)句默認(rèn)按照升序?qū)τ涗涍M(jìn)行排序。如果希望按照降序?qū)τ涗涍M(jìn)行排序拍屑,可以使用 DESC 關(guān)鍵字躯护。
- 可以使用任何字段來(lái)作為排序的條件,從而返回排序后的查詢結(jié)果丽涩。
- 可以設(shè)定多個(gè)字段來(lái)排序棺滞。
- 可以使用 ASC 或 DESC 關(guān)鍵字來(lái)設(shè)置查詢結(jié)果是按升序或降序排列。 默認(rèn)情況下矢渊,它是按升序排列继准。
- 可以添加 WHERE...LIKE 子句來(lái)設(shè)置條件。
3.操作示例
目標(biāo):對(duì)yiibaidb數(shù)據(jù)庫(kù)customers表數(shù)據(jù)先按照customername排序矮男,再按照customernumber排序
三移必、函數(shù)
MySQL 有很多內(nèi)置的函數(shù):
- 字符串函數(shù)
- 數(shù)字函數(shù)
- 日期函數(shù)
四、SQL注釋
(一)單行注釋
1.使用 #
#單行注釋方法一
select * from customers;
或者
2.使用--
-- 單行注釋方法二
select * from customers
注意:--后跟有一個(gè)空格
(二)多行注釋
注釋從 /* 開(kāi)始,到 / 結(jié)束, / 和 */ 之間的任何內(nèi)容都是注釋毡鉴。
/*
此處為注釋....
*/
select * from customers;
五崔泵、SQL代碼規(guī)范
可參看
SQL編程格式的優(yōu)化建議
SQL style guide by Simon Holywell
練習(xí)
練習(xí)一:查找重復(fù)的電子郵箱(難度:簡(jiǎn)單)
創(chuàng)建 email表,并插入如下三行數(shù)據(jù)
+----+---------+
| Id | Email |
+----+---------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
+----+---------+
編寫(xiě)一個(gè) SQL 查詢猪瞬,查找 email 表中所有重復(fù)的電子郵箱憎瘸。
根據(jù)以上輸入,你的查詢應(yīng)返回以下結(jié)果:
+---------+
| Email |
+---------+
| a@b.com |
+---------+
說(shuō)明:所有電子郵箱都是小寫(xiě)字母陈瘦。
第一步:新建數(shù)據(jù)庫(kù)
mysql> CREATE DATABASE IF NOT EXISTS emailtest DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
mysql> use emailtest;
第二步:新建數(shù)據(jù)表
mysql> CREATE TABLE email ( ID INT NOT NULL PRIMARY KEY, Email VARCHAR(255))幌甘;
第三步:插入數(shù)據(jù)
mysql> INSERT INTO email VALUES('1','a@b.com');
mysql> INSERT INTO email VALUES('2','c@d.com');
mysql> INSERT INTO email VALUES('3','a@b.com');
第四步:查詢數(shù)據(jù)
SELECT Email FROM email GROUP BY Email HAVING COUNT(Email)>1
項(xiàng)目二:查找大國(guó)(難度:簡(jiǎn)單)
創(chuàng)建如下 World 表
+-----------------+------------+------------+--------------+---------------+
| name | continent | area | population | gdp |
+-----------------+------------+------------+--------------+---------------+
| Afghanistan | Asia | 652230 | 25500100 | 20343000 |
| Albania | Europe | 28748 | 2831741 | 12960000 |
| Algeria | Africa | 2381741 | 37100000 | 188681000 |
| Andorra | Europe | 468 | 78115 | 3712000 |
| Angola | Africa | 1246700 | 20609294 | 100990000 |
+-----------------+------------+------------+--------------+---------------+
如果一個(gè)國(guó)家的面積超過(guò)300萬(wàn)平方公里,或者(人口超過(guò)2500萬(wàn)并且gdp超過(guò)2000萬(wàn))痊项,那么這個(gè)國(guó)家就是大國(guó)家锅风。
編寫(xiě)一個(gè)SQL查詢,輸出表中所有大國(guó)家的名稱鞍泉、人口和面積皱埠。
例如,根據(jù)上表咖驮,我們應(yīng)該輸出:
+--------------+-------------+--------------+
| name | population | area |
+--------------+-------------+--------------+
| Afghanistan | 25500100 | 652230 |
| Algeria | 37100000 | 2381741 |
+--------------+-------------+--------------+
第一步:新建數(shù)據(jù)庫(kù)
mysql> CREATE DATABASE IF NOT EXISTS worldtest DEFAULT CHARSET utf8 COLLATE utf8_general_ci;
mysql> use worldtest;
第二步:新建數(shù)據(jù)表
mysql> CREATE TABLE World ( name VARCHAR(50) NOT NULL,continent VARCHAR(50) NOT NULL,
area INT NOT NULL,population INT NOT NULL,gdp INT NOT NULL);
第三步:插入數(shù)據(jù)
mysql>INSERT INTO World VALUES( 'Afghanistan', 'Asia',652230,25500100,20343000);
mysql>INSERT INTO World VALUES( 'Albania', 'Europe' ,28748,2831741,12960000);
mysql>INSERT INTO World VALUES( 'Algeria', 'Africa' ,2381741,37100000,188681000);
mysql>INSERT INTO World VALUES( 'Andorra' , 'Europe' ,468,78115,3712000);
mysql>INSERT INTO World VALUES( 'Angola' , 'Africa' ,1246700,20609294,100990000);
第四步:查詢數(shù)據(jù)
SELECT name, population, area FROM world WHERE area > 3000000 OR (population>25000000 AND gdp>20000000);
參考資料:
1.MySQL導(dǎo)入示例數(shù)據(jù)庫(kù)
2.MySQL命令行學(xué)習(xí)
3.MySQL命令行工具和基本操作
4.MySQL基礎(chǔ) - 查詢語(yǔ)句
5.MySQL 教程
6.SQL的case when then else end語(yǔ)句的用法