作者:俊欣
來源:關(guān)于數(shù)據(jù)分析與可視化
作為數(shù)據(jù)分析師,每天需要花費(fèi)大量的時(shí)間來分析與挖掘數(shù)據(jù)當(dāng)中隱藏的信息,發(fā)現(xiàn)新的價(jià)值,而現(xiàn)在絕大多數(shù)公司都是將數(shù)據(jù)存放在Mysql數(shù)據(jù)庫(kù)當(dāng)中,今天小編來分享25個(gè)針對(duì)每個(gè)數(shù)據(jù)分析初學(xué)者而言都需要掌握的SQL查詢語句。
查詢所有行的數(shù)據(jù)
這個(gè)也是最基本的SQL查詢了,假設(shè)我們有一張員工表“Employee”,當(dāng)中包含了一系列員工的信息,包括薪水、所屬的國(guó)家等內(nèi)容
SELECT * FROM Employee;
查詢指定行的數(shù)據(jù)
我們更進(jìn)一步,想要查詢指定某一行的數(shù)據(jù),這里我們查詢的是員工的ID、員工的姓以及員工的名,代碼如下
SELECT EmployeeID, LastName, FirstNameFROM Employee;
篩選數(shù)據(jù)
我們想要進(jìn)一步地篩選數(shù)據(jù),在SQL當(dāng)中添加相對(duì)應(yīng)的條件,例如想要查看國(guó)家是德國(guó)的員工,代碼如下
SELECT * FROM Employee WHERE Location = 'Germany';
多個(gè)條件來篩選數(shù)據(jù)
上面的例子當(dāng)中,我們只是添加了一個(gè)條件,那要是不止只有一個(gè)條件該怎么辦呢?
SELECT * FROM EmployeeWHERE salary > 10000 AND Location = 'UK';
去重
我們有時(shí)候查詢到的數(shù)據(jù)帶有重復(fù)值,可以用DISTINCT來進(jìn)行去重
SELECT DISTINCT EmployeeID,SalaryFROM Employee;
排序
排序用到的則是ORDER BY方法,例如我們想要按照員工的名來進(jìn)行排序,代碼如下
SELECT EmployeeID, FirstNameFROM EmployeeORDER BY FirstName
不止一列的數(shù)據(jù)需要排序
那要是我們需要對(duì)不止一行的數(shù)據(jù)進(jìn)行排序,該怎么做呢?代碼如下
SELECT EmployeeID, FirstNameFROM EmployeeORDER BY FirstName DESC,EmployeeID;
其中DESC是降序(descending)的縮寫,上面的代理邏輯是對(duì)員工的FirstName進(jìn)行降序的排列,對(duì)EmployeeID這列進(jìn)行升序的排列
篩選出不是空值的數(shù)據(jù)
要是我們想要篩選出不是空值的數(shù)據(jù),例如我們針對(duì)的就是FirstName這一列的數(shù)據(jù),代碼如下
SELECT EmployeeID, FirstNameFROM EmployeeWHERE FirstName IS NOT NULL;
通配符的魅力
通配符的作用就在于可以方便我們進(jìn)行數(shù)據(jù)的篩選,例如FirstName這一列當(dāng)中含有“a”的數(shù)據(jù),
SELECT EmployeeID, FirstNameFROM EmployeeWHERE FirstName LIKE '%a%';
CONCAT()函數(shù)
concat()函數(shù)用于將兩個(gè)字符串連接起來,形成一個(gè)單一的字符串,例如我們可以將FirstName和LastName這兩列的數(shù)據(jù)給連接起來,這樣就可以每一位員工完整的姓名啦
SELECT CONCAT(FirstName, ' ', LastName)FROM Employee;
并集
要是我們將多個(gè)SQL語句查詢得到的結(jié)果集合并到一起,就要用到UNION ALL操作符了,例如我們將員工表中的“l(fā)ast_name”這一列和學(xué)生表中的“l(fā)ast_name”這一列合并到一塊顯示
SELECT last_name FROM EmployeeUNION ALLSELECT last_name FROM Student;
交集
而INTERSECT操作符則是在多個(gè)SQL語句查詢得到的結(jié)果中尋找交集,代碼如下
SELECT last_name FROM EmployeeINTERSECTSELECT last_name FROM Student;
數(shù)學(xué)運(yùn)算
針對(duì)是數(shù)值類型的數(shù)據(jù),我們也可以在其中進(jìn)行加減乘除的數(shù)學(xué)運(yùn)算,例如
SELECT TotalSalary - GrossSalaryFROM Employee;
但是前提得是這兩列當(dāng)中的數(shù)據(jù)都得是數(shù)值類型的數(shù)據(jù),整型或者是浮點(diǎn)數(shù)
計(jì)算數(shù)據(jù)總共有幾行
這里用到的是COOUNT()方法,例如我們想要計(jì)算一下student_id有多少個(gè)的時(shí)候
SELECT COUNT(student_id)FROM student;
平均數(shù)
平均數(shù)的計(jì)算用到的是AVG()方法,例如計(jì)算平均工資,代碼如下
SELECT AVG(Salary)FROM Employee;
最大值
最大值用到的是MAX()方法,例如查詢一下哪位員工的工資拿的最多,代碼如下
SELECT MAX(Salary)FROM Employee;
最小值
直接上代碼吧
SELECT MIN(Salary)FROM Employee;
插入數(shù)據(jù)
要是我們想要往表格當(dāng)中插入新的數(shù)據(jù),代碼如下
INSERT INTO Employee (EmployeeID, FirstName, LastName)VALUES (‘A0001’, ‘Dom’, ‘Werler’),
更新數(shù)據(jù)
更新數(shù)據(jù)用到的是UPDATE方法,后面跟著是表名,例如我們想要將Employee表中Salary這一列的數(shù)據(jù)都改成2000,代碼如下
UPDATE Employee SET Salary = 20000;
新建一張表
例如我們想要新建一張員工表,調(diào)用的是CREATE TABLE方法,而表中的每一列需要寫清楚列名以及其數(shù)據(jù)類型,代碼如下
CREATE TABLE Employee(EmployeeID int, Firstname varchar(50));
刪除表內(nèi)的所有數(shù)據(jù)
DELETE FROM Employee;
刪除某張表格
表格當(dāng)中的所有數(shù)據(jù)都刪除,我們還能后續(xù)繼續(xù)往里面添加真的數(shù)據(jù),但是要是直接將表格都刪掉,就不能執(zhí)行添加新數(shù)據(jù)的操作了,因?yàn)楫吘贡砀穸紱]了,代碼如下
DROP TABLE Employee;
完 謝謝觀看