學習mysql語法--基礎篇(二)


 

  前  言

 mysql 

 mysql語法--本篇學習都是通過使用Navicat Premium(數據庫管理工具,連接mysql數據.

本篇學習主要有兩個部分:

 【SQL語句的組成】
    DML 數據操作語言(插入、刪除和修改數據庫中的數據)INSERT UPDATE DELETE
    DQL 數據查詢語言(用來查詢數據庫中的數據)SELECT
    DCL 數據控制語言(用來控制存取許可、存取權限等)CREATE
    DDL 數據定義語言(用來建立數據庫、數據庫對象和定義表的列)CREATE DROP
【常用的函數】
  數學函數
  字符串函數
  常用日期函數
  系統信息函數
  加密函數
  多行函數
【綜合操作】
  分組操作
  限制行數
  內連接
  自連接

以下所有代碼全部在新建查詢表里面使用mysql語法編輯。

 

1、DML 數據操作語言(INSERT UPDATE DELETE)

① 數據插入語句 insert
     INSERT [INTO] 表明 [列名]  VALUES (列值)[,(列值),……];
     ① 如果省略列名,則后面的列值必須為所有的列復制,包括自增列和默認列;
     ② 如果不省略列名,則后面的列值需要與前面的列名一一對應;並且需要給雖有非null列復制

② 數據更新語句 update
    update 表明 set 列名=列值[,列名=列值,……] [where 條件]
    where 條件可以省略,但是表示修改表中所有的行

③  刪除表中數據 delete
    delete [FROM] 表名 [where 條件]


 

-- 選中mydb數據庫
USE mydb;

-- 在mydb中建立一個名字為tb1表單
-- 內有三個屬性,分別為id,username,age,sex
CREATE TABLE IF NOT EXISTS tb1(
    id INT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(255) NOT NULL,
    age INT DEFAULT 0,
  sex enum("男","女") DEFAULT "男"
);



--  ↓給表tb1添加一行數據
INSERT INTO tb1 (username,age,sex) VALUES ("張三","122","女");

--  ↓給表tb1添加一行數據 age和sex 沒有數據
INSERT INTO tb1 (username) VALUES ("李四");

--  ↓給表tb1添加一行數據id為7的行中添加數據,如果有id7,依然在表后部添加
insert tb1 VALUES (7,"王二",12,"女");

-- 添加多行數據
INSERT INTO tb1 (username,age,sex) VALUES ("張四",12,"女"),("張五",12,"女"),("張六",12,"女");

-- 更新 where 后面的條件的 行內數據
UPDATE tb1 SET username="帥哥",age=18,sex="男" where id=8;
UPDATE tb1 SET username="王五",age=18,sex="男" where id=7;
-- 刪除ID為10 的那行數據
delete from tb1 WHERE id=10;

 

 

2、DQL 數據查詢語言 select
   
  數據查詢語言 select
      -- select 列名[,列名,……] from 表名 where 條件 order by 排序的列名 asc/desc
      -- ① select * 表示查詢所有字段;
      -- ② order by 表示對查出的數據進行排序,必須在where后面;
      --    asc 表示升序排列 desc 表示降序排列
           -- 列表達式
      -- 根據已有的列查詢出來的結果,我們使用case結構虛擬出來的列,稱為列表達式

      -- as 關鍵字
      -- 用於給列名其別名,as關鍵字還可以省略。



 

-- 顯示表格的全部內容
SELECT * FROM tb1;

-- 顯示表格的age列 不為null的內容
SELECT * from tb1 where not ISNULL(age);

-- 查詢tb表中的所有數據 按id 降序排流
select * from tb1 order by id desc ;

-- 查詢tb表中的所有數據 按id 升序排流
select * from tb1 order by id asc ;

-- 列表達式
-- 根據已有的列查詢出來的結果,我們使用case結構虛擬出來的列,稱為列表達式

-- as 關鍵字
-- 用於給列名其別名,as關鍵字還可以省略。

select username as "姓名",sex "性別",age,( -- 給username列起別名"名字",sex起別名"性別"

    CASE     -- case 表示判斷的開始
        when sex="男" then 1   -- 如果查詢出sex 是男,則虛擬的列表達式的值就是1
        when sex="女" then 2
    else 3                                   -- 上面所有的wen都不成立時,列表達式的值為3
END                                              -- END 表示判斷的結束

) as sexno    -- 給細膩出的這一列,起別名叫 sexno 
 from tb1;


-- DISTINCT 對查詢之后的結果去重。
select distinct age from tb1;

 

3、數據控制語言/數據定義語言(CREATE DROP)
   
 【CREATE

    -- 創建用戶:CREATE USER '用戶名'@'主機名' IDENTIFIED BY '密碼';
    -- 主機名可以為空,為空默認為%權限,表示所有主機可連接。
    -- 給用戶分配權限: GRANT 權限名 ON 數據庫名.表明 TO 用戶名@主機名
    -- 給用戶分配權限: GRANT 權限名 ON 數據庫名.表明 TO 用戶名@主機名
    -- 創建數據庫: CREATE DATABASE [IF NOT EXISTS] 數據庫名[CHARACTER SET[=] 'UTF8'];
    -- 如果省略 [IF NOT EXISTS] 在重復創建數據庫時,會報錯!

 【DROP
    -- 關閉數據庫 DROP DATABASE [IF EXISTS] 數據庫
    -- 如果省略 [IF EXISTS] 在不存在關閉數據庫時,會報錯!
  
         

 

CREATE TABLE IF NOT EXISTS tb1( 
-- IF NOT EXISTS 可以省略,省略后重復創建報錯.如果不省略,則創建時會檢測表是否已存在,如果表存在則不再執行創建語句
    id INT(3),
    `name` VARCHAR(255) NOT null, -- name是系統關鍵字,所以使用反引號``包裹
    age SMALLINT(3) AUTO_INCREMENT PRIMARY KEY,
    lalala INT UNIQUE,
 height DOUBLE(3,2) DEFAULT 1.2 -- 設置默認值約束:默認值為1.2
-- PRIMARY KEY(age)
);



create table if not exists classes(
 id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
  classname VARCHAR(255) NOT NULL 

);


CREATE table if not EXISTS `user`(
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    clsId INT UNSIGNED,
    `name` VARCHAR(255) NOT NULL,
 CONSTRAINT user_fk_classes FOREIGN KEY (clsid) REFERENCES classes(id) ON DELETE SET NULL on update CASCADE
)
-- auto_increment


-- 顯示表結構
SHOW TABLES;

-- 顯示表內容結構
SHOW COLUMNS FROM TB1;

-- 現實表的建表語句
show create TABLE tb1;

-- 刪除表
DROP TABLE IF EXISTS TB1;
DROP TABLE IF EXISTS classes;
DROP TABLE IF EXISTS `user`;

-- 修改表名 
ALTER table tb1 rename tb2;

-- 修改字段 列
-- alter table 表名 change 舊列名 新列名 列定義 [first|after某一列]
-- first 將這個字段調整為表格第一列; after某一列: 將這個字段放到某一列后面
alter table tb1 change height width VARCHAR(200) not NULL FIRST; 



-- 刪除表中某一列
alter table tb1 drop name;

-- 新增一列:必選部分:alter table tb1 add haha DOUBLE(8,2)
alter table tb1 add haha DOUBLE(8,2) DEFAULT 1.2 after age;

-- 新增多列:不能調整列的位置,只能插在最后。
alter table tb1 add (
    ha1 DOUBLE(3,2) UNSIGNED,
    ha2 VARCHAR(255)
);


-- 同時修改多表明  rename table tb3 to tb1[,`USER`to user1];
rename table tb2 to tb1,`USER`to user1;


-- 增加主鍵約束
alter table tb1 add PRIMARY KEY(id);

-- 刪除主鍵約束
alter table tb1 drop PRIMARY KEY;

-- 新增唯一性約束
ALTER table tb1 add unique key(ha1);

-- 刪除唯一性約束:由於創建唯一性約束會默認創建索引,所以刪除時,需刪除索引
ALTER table tb1 drop index ha1;

    
-- 設置默認值約束:前提必須設置default 屬性
ALTER table tb1 alter ha1 set default 20;

-- 刪除默認值約束
ALTER table tb1 alter haha drop default;

-- 設置外鍵約束 必選部分  alter table tb1 add  foreign key (clsid)REFERENCES classes(id)
alter table tb1 add constraint waijianming foreign key (clsid)REFERENCES classes(id) ON DELETE SET NULL on update CASCADE;

-- 刪除外鍵約束,由於常見外鍵時會生成索引,所以刪除外鍵后,需要刪索引。
alter table tb1 drop foreign key waijianming;

alter table tb1 drop INDEX waijianming;

SHOW COLUMNS FROM TB1;

 

 

4、常用的函數
 
①  數學函數
  ABS(X)             返回 絕對值
  CELL(X)         向上取整                      1.5-->2   -1.5-->-1
  FLOOR(X)         向下取整                   1.5-->1   -1.5-->-2
  ROUND(X)        四舍五入取整            1.4-->1   1.5-->2
  ROUND(X,D)    將X保留D位小數,進行四舍五入    
`  TRUNCATE`(X,D)  將X保留D位小數,不進行四舍五入
  sign(X)           X為負數返回-1  0返回0  正數返回1
  pow(X,D)          返回X的D次方

②  字符串函數
  LENGTH(str)                             返回字符串的長度。其中一個中文占三個字符;
  CHAR_LENGTH(str)                  返回字符串的字符數。其中一個中文只占一個字符;
  CONCAT(str1,str2,...)            拼接多個字符串;
  UPPER(str)                                將字符串全部轉為大寫;
  LOWER(str)                                將字符串全部轉為小寫;
  left(str,n)                                返回字符串的前N個字符;
  right(str,n)                            返回字符串的后N個字符;
  TRIM(str)                                    去掉str兩端的空格;
  REPLACE(str,s1,s2)               將str中所有的s1換為s2;
  substring(str,pos[,Len])            截取字符串str,從第pos個字符開始,截取len個。如果省略len,則從第pos個字符截取到最后;
  INSTR(str,s1)                            返回s1在str的下標 INSTR("12-23","-")-->3  下標從1開始。
SELECT LENGTH("哈哈哈哈");
SELECT CHAR_LENGTH("哈哈哈哈");
SELECT concat("123","456","789");
SELECT UPPER("hahahaha");
SELECT LEFT ("abcdefg",5);
SELECT trim ("  hahahaha    ");
SELECT substr("abcdefghigklmn",3,5);
SELECT substring("abcdefghigklmn",3,5);


③  常用日期函數
  CURDATE()   返回當前日期。 2017-06-20
  CURTIME()        返回當前時間。 09:57:51
                返回當前的日期和時間。
  DATEDIFF(expr1,expr2)  返回從expr1天到expr2天的天數。
  ADDDATE(expr1,len)       返回從expr1當天到len天數。
  
  YEAR(date)    返回日期中的年份
  MONTH(date)                        返回日期中的月份
  DAY(date)                            返回日期中一個的中的第幾天
  WEEKDAY(date)                    返回一周中的第幾天 0->周一
  HOUR(time)                        返回小時數
  MINUTE(time)                    返回分鍾數
  SECOND()                            返回秒數



  DATE_FORMAT(date1,format): 將date1使用format要求的格式顯示。

  format中可用的占位符格式:

  %Y年份, 數字形式,4位數
  %y年份, 數字形式 (2位數)

  %M月份名稱 (January..December)
  %m月份, 數字形式 (00..12)
  %b月份的縮寫名稱  (Jan..Dec)
  %c月份,數字形式(0..12)

  %D帶有英語后綴的該月日期  (0th, 1st, 2nd, 3rd, ...)
  %d該月日期, 數字形式 (00..31)
  %e該月日期, 數字形式(0..31)
 
  %H小時(00..23)
  %h小時(01..12)
  %k小時(0..23)
  %l小時(1..12)
 
  %i分鍾,數字形式 (00..59)

  %S秒 (00..59)
  %s秒 (00..59)
 
  %W工作日名稱 (周日..周六)
  %w一周中的每日 (0=周日..6=周六)
SELECT CURDATE();
SELECT CURTIME();
SELECT NOW();
SELECT DATEDIFF(NOW(),"1996-06-03");
SELECT ADDDATE(NOW(),100);
SELECT YEAR("1996-06-03");
SELECT WEEKDAY("2017-06-18");
SELECT HOUR(CURTIME());
SELECT MINUTE(CURTIME());
SELECT SECOND(CURTIME());
SELECT DAY(NOW());

 



④  系統信息函數
  VERSION();                   取到當前數據庫的版本號
  DATABASE();                    返回當前數據庫的名字
  USER();                            返回當前數據庫的用戶
  CHARSET(str);                返回字符串的字符集
  LAST_INSERT_ID();     返回最后一個auto_increment 的值
 

⑤  加密函數
  1、PASSWORD(str)                        對字符串進行加密,常用於加密密碼
  2、MD5(str)                                    對字符串進行MD5散列加密,常用語不需要解密數據
  3、ENCODE(str,pwd_str)            使用加密密碼pwd對字符串str進行加密;
                                                          加密之后的結果是二進制,該字段需要使用BLOB類型保存
       DECODE(mistr,pwd_str)        將ENCODE加密的二進制進行解密,解密密碼需與ENCODE的加密密碼一致。
SELECT PASSWORD("哈哈哈");
SELECT MD5("哈哈哈");


SELECT ENCODE("neirong","mima");
SELECT DECODE(ENCODE("neirong","mima"),"mima");

UPDATE `Card` SET `PASSWORD` = REPLACE(REPLACE(`PASSWORD`,"O","0"),"i","1");

⑥  多行函數
  sum():求和
  avg():求均值
  min():求最小值
  max():求最大值
  count():求總個數 select count(username) from tb2
        
SELECT * FROM cusinfo;
-- 要求統計客戶信用度為3的客戶數量
SELECT COUNT(*) FROM cusinfo WHERE cuscredit=3;
-- 要求統計本月度客戶訂單的總和以及最高最高的客戶訂單額度
SELECT SUM(ordmoney)"總和",MAX(ordmoney)"最大值" from cusorder;

 

5、綜合操作

select …… FROM <表名>
where ……
GROUP BY ……
HAVING ……

上述代碼執行流程:
① 先select……from…… 查詢所有數據
② 使用where 將數據進行篩選
③ 對where篩選后的數據,使用group by 進行分組;
-- 分為N組后,使用聚合函數時,將會產生N條數據。
④ HAVING 字句對產生的多條聚合數據,進行處理操作。

注意事項:
① 代碼順序必須是: where -> GROUP BY -> HAVING
② 有having字句,必須有group by;有group by並不一定有HAVING
③ where和having區別?
        where是在分組之前先篩選數據;having是對分組之后的數據,進行篩選;
        where語句中一定不能包含聚合函數。
        having是專門用來過濾聚合函數的,

>>> 求出,平均薪資大於1萬的部門的平均薪資?
        注:各部門出勤記錄大於15天的員工的平均薪資。  

SELECT avg(薪資) from 公司表 where 出勤率>15 group by 部門 having avg(薪資)>10000  
         

 

use mydb;

SELECT * FROM cusinfo;


  
-- 需要對客戶構成進行分析,要求按照客戶等級顯示客戶數量
set @count = 0;
SELECT (@count := @count +1)"序號",cuslevel"客戶等級",COUNT(*)"客戶數量" 
FROM cusinfo GROUP BY cuslevel
ORDER BY @count;


-- 需要對客戶構成進行分析,要求計算不同區域客戶的數量在5個以上的統計報表
SELECT cusregion"客戶地區",COUNT(1)"客戶數量" FROM cusinfo 
GROUP BY cusregion HAVING COUNT(1)>5


-- 需要對客戶貢獻進行分析,要求統計本年度每個客戶訂單的總額
set @count = 0;
SELECT (@count := @count +1)"序號",i.cusname"客戶編號",o.ordmoney"訂單金額" -- 多表關聯,字段前必須有表名
FROM cusorder as o,cusinfo as i -- 為了方便書寫,給表起別名
WHERE o.cusno=i.cusno; --  兩張表通過哪個鍵連接


-- (內連接)需要對客戶貢獻進行分析,要求統計本年度每個客戶訂單的總額
set @count = 0;
SELECT (@count := @count +1)"序號",i.cusname"客戶編號",o.ordmoney"訂單金額" -- 多表關聯,字段前必須有表名
FROM cusorder as o INNER JOIN cusinfo as i -- 為了方便書寫,給表起別名
on o.cusno=i.cusno; --  兩張表通過哪個鍵連接



-- 內連接 INNER JOIN
-- 特點:相關聯的兩張表,總是以數據少的為准。
-- 另一張表中,沒有被匹配的表,會被刪除不顯示。

-- 左外連接 left JOIN 
-- 特點: 以左邊的表為准
-- 把左表的全部數據顯示,右表多的刪除不顯示,右表少的補null。

-- 右外連接 left JOIN 
-- 特點: 以右邊的表為准
-- 把右表的全部數據顯示,左表多的刪除不顯示,左表少的補null。



/*[自連接]同一張表與自己鏈接
SELECT e1.ename"雇員",e2.ename"領導"
FROM emp e1 LEFT JOIN emp e2
ON e1.mgr=e2.empno
*/



-- 訂單明細(產品編號、產品數量、產品單價)及訂單(訂單編號,訂購日期)信息
SELECT od.*,o.orddate
FROM cusorderdetail od,cusorder o
WHERE o.ordno=od.ordno;


/*[限制行數]
LIMIT n 前n條數據     相當於LIMIT 0,n
LIMTT n,m 第n+1 到 第M條 

*/

SELECT * from tb1 LIMIT 5;

SET @page = 1; -- 第幾頁
SET @rows = 5; -- 每頁幾條
-- 分頁語句
SELECT * FROM cusorder LIMIT @rows*(@page-1),@rows*@page;






/*
各種限制語句的順序
*/ 

select *,sum(ordmoney) FROM cusorder
WHERE NOT ISNULL(ordno)
GROUP BY ordno
having SUM(ordmoney)>0
ORDER BY ordmoney DESC
LIMIT 0,10

 

 

學習時候的筆記,可能會有一些錯誤的地方,歡迎各位的批評指點。

反思,復盤,每天收獲一點---------------------期待更好的自己

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM