Mysql高手系列 - 第18篇:mysql流程控制語句詳解(高手進階)

Mysql系列的目標是:經過這個系列從入門到全面掌握一個高級開發所須要的所有技能。html

這是Mysql系列第18篇。java

環境:mysql5.7.25,cmd命令中進行演示。mysql

代碼中被[]包含的表示可選,|符號分開的表示可選其一。sql

上一篇存儲過程&自定義函數,對存儲過程和自定義函數作了一個簡單的介紹,可是如何可以寫出複雜的存儲過程和函數呢?數據庫

這須要咱們熟練掌握流程控制語句才能夠,本文主要介紹mysql中流程控制語句的使用,上乾貨。微信

本篇內容

  • if函數
  • case語句
  • if結構
  • while循環
  • repeat循環
  • loop循環
  • 循環體控制語句

準備數據

/*建庫javacode2018*/
drop database if exists javacode2018;
create database javacode2018;

/*切換到javacode2018庫*/
use javacode2018;

/*建立表:t_user*/
DROP TABLE IF EXISTS t_user;
CREATE TABLE t_user(
  id int PRIMARY KEY COMMENT '編號',
  sex TINYINT not null DEFAULT 1 COMMENT '性別,1:男,2:女',
  name VARCHAR(16) not NULL DEFAULT '' COMMENT '姓名'
)COMMENT '用戶表';

/*插入數據*/
INSERT INTO t_user VALUES
(1,1,'路人甲Java'),(2,1,'張學友'),(3,2,'王祖賢'),(4,1,'郭富城'),(5,2,'李嘉欣');

SELECT * FROM t_user;

DROP TABLE IF EXISTS test1;
CREATE TABLE test1 (a int not null);

DROP TABLE IF EXISTS test2;
CREATE TABLE test2 (a int not null,b int NOT NULL );

if函數

語法

if(條件表達式,值1,值2);

if函數有3個參數。函數

當參數1爲true的時候,返回值1,不然返回值2oop

示例

需求:查詢t_user表數據,返回:編號、性別(男、女)、姓名。spa

分析一下:數據庫中性別用數字表示的,咱們須要將其轉換爲(男、女),可使用if函數。3d

mysql> SELECT id 編號,if(sex=1,'男','女') 性別,name 姓名 FROM t_user;
+--------+--------+---------------+
| 編號   | 性別   | 姓名          |
+--------+--------+---------------+
|      1 | 男     | 路人甲Java    |
|      2 | 男     | 張學友        |
|      3 | 女     | 王祖賢        |
|      4 | 男     | 郭富城        |
|      5 | 女     | 李嘉欣        |
+--------+--------+---------------+
5 rows in set (0.00 sec)

CASE結構

2種用法。

第1種用法

相似於java中的switch語句。

case 表達式
when 值1 then 結果1或者語句1(若是是語句須要加分號)
when 值2 then 結果2或者語句2
...
else 結果n或者語句n
end [case] (若是是放在begin end之間須要加case,若是在select後則不須要)
示例1:select中使用

查詢t_user表數據,返回:編號、性別(男、女)、姓名。

/*寫法1:相似於java中的if else*/
SELECT id 編號,(CASE sex WHEN 1 THEN '男' ELSE '女' END) 性別,name 姓名 FROM t_user;
/*寫法2:相似於java中的if else if*/
SELECT id 編號,(CASE sex WHEN 1 then '男' WHEN 2 then '女' END) 性別,name 姓名 FROM t_user;
示例2:begin end中使用

寫一個存儲過程,接受3個參數:id,性別(男、女),姓名,而後插入到t_user表

建立存儲過程:

/*刪除存儲過程proc1*/
DROP PROCEDURE IF EXISTS proc1;
/*s刪除id=6的記錄*/
DELETE FROM t_user WHERE id=6;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程proc1*/
CREATE PROCEDURE proc1(id int,sex_str varchar(8),name varchar(16))
  BEGIN
    /*聲明變量v_sex用於存放性別*/
    DECLARE v_sex TINYINT UNSIGNED;
    /*根據sex_str的值來設置性別*/
    CASE sex_str
      when '男' THEN
      SET v_sex = 1;
    WHEN '女' THEN
      SET v_sex = 2;
    END CASE ;
    /*插入數據*/
    INSERT INTO t_user VALUES (id,v_sex,name);
  END $
/*結束符置爲;*/
DELIMITER ;

調用存儲過程:

CALL proc1(6,'男','郭富城');

查看效果:

mysql> select * from t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
+----+-----+---------------+
6 rows in set (0.00 sec)

示例3:函數中使用

需求:寫一個函數,根據t_user表sex的值,返回男女

建立函數:

/*刪除存儲過程proc1*/
DROP FUNCTION IF EXISTS fun1;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程proc1*/
CREATE FUNCTION fun1(sex TINYINT UNSIGNED)
  RETURNS varchar(8)
  BEGIN
    /*聲明變量v_sex用於存放性別*/
    DECLARE v_sex VARCHAR(8);
    CASE sex
    WHEN 1 THEN
      SET v_sex:='男';
    ELSE
      SET v_sex:='女';
    END CASE;
    RETURN v_sex;
  END $
/*結束符置爲;*/
DELIMITER ;

看一下效果:

mysql> select sex, fun1(sex) 性別,name FROM t_user;
+-----+--------+---------------+
| sex | 性別   | name          |
+-----+--------+---------------+
|   1 | 男     | 路人甲Java    |
|   1 | 男     | 張學友        |
|   2 | 女     | 王祖賢        |
|   1 | 男     | 郭富城        |
|   2 | 女     | 李嘉欣        |
|   1 | 男     | 郭富城        |
+-----+--------+---------------+
6 rows in set (0.00 sec)

第2種用法

相似於java中多重if語句。

case
when 條件1 then 結果1或者語句1(若是是語句須要加分號)
when 條件2 then 結果2或者語句2
...
else 結果n或者語句n
end [case] (若是是放在begin end之間須要加case,若是是在select後面case能夠省略)

這種寫法和1中的相似,你們用上面這種語法實現第1中用法中的3個示例,貼在留言中。

if結構

if結構相似於java中的 if..else if...else的語法,以下:

if 條件語句1 then 語句1;
elseif 條件語句2 then 語句2;
...
else 語句n;
end if;

只能使用在begin end之間。

示例

寫一個存儲過程,實現用戶數據的插入和新增,若是id存在,則修改,不存在則新增,並返回結果

/*刪除id=7的記錄*/
DELETE FROM t_user WHERE id=7;
/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc2;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc2(v_id int,v_sex varchar(8),v_name varchar(16),OUT result TINYINT)
  BEGIN
    DECLARE v_count TINYINT DEFAULT 0;/*用來保存user記錄的數量*/
    /*根據v_id查詢數據放入v_count中*/
    select count(id) into v_count from t_user where id = v_id;
    /*v_count>0表示數據存在,則修改,不然新增*/
    if v_count>0 THEN
      BEGIN
        DECLARE lsex TINYINT;
        select if(lsex='男',1,2) into lsex;
        update t_user set sex = lsex,name = v_name where id = v_id;
        /*獲取update影響行數*/
        select ROW_COUNT() INTO result;
      END;
    else
      BEGIN
        DECLARE lsex TINYINT;
        select if(lsex='男',1,2) into lsex;
        insert into t_user VALUES (v_id,lsex,v_name);
        select 0 into result;
      END;
    END IF;
  END $
/*結束符置爲;*/
DELIMITER ;

看效果:

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
+----+-----+---------------+
6 rows in set (0.00 sec)

mysql> CALL proc2(7,'男','黎明',@result);
Query OK, 1 row affected (0.00 sec)

mysql> SELECT @result;
+---------+
| @result |
+---------+
|       0 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
|  7 |   2 | 黎明          |
+----+-----+---------------+
7 rows in set (0.00 sec)

mysql> CALL proc2(7,'男','梁朝偉',@result);
Query OK, 1 row affected (0.00 sec)

mysql> SELECT @result;
+---------+
| @result |
+---------+
|       1 |
+---------+
1 row in set (0.00 sec)

mysql> SELECT * FROM t_user;
+----+-----+---------------+
| id | sex | name          |
+----+-----+---------------+
|  1 |   1 | 路人甲Java    |
|  2 |   1 | 張學友        |
|  3 |   2 | 王祖賢        |
|  4 |   1 | 郭富城        |
|  5 |   2 | 李嘉欣        |
|  6 |   1 | 郭富城        |
|  7 |   2 | 梁朝偉        |
+----+-----+---------------+
7 rows in set (0.00 sec)

循環

mysql中循環有3種寫法

  1. while:相似於java中的while循環
  2. repeat:相似於java中的do while循環
  3. loop:相似於java中的while(true)死循環,須要在內部進行控制。

循環控制

對循環內部的流程進行控制,如:

結束本次循環

相似於java中的continue

iterate 循環標籤;
退出循環

相似於java中的break

leave 循環標籤;

下面咱們分別介紹3種循環的使用。

while循環

相似於java中的while循環。

語法

[標籤:]while 循環條件 do
循環體
end while [標籤];

標籤:是給while取個名字,標籤和iterateleave結合用於在循環內部對循環進行控制:如:跳出循環、結束本次循環。

注意:這個循環先判斷條件,條件成立以後,纔會執行循環體,每次執行都會先進行判斷。

示例1:無循環控制語句

根據傳入的參數v_count向test1表插入指定數量的數據。

/*刪除test1表記錄*/
DELETE FROM test1;
/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc3;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc3(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:WHILE i<=v_count DO
      INSERT into test1 values (i);
      SET i=i+1;
    END WHILE;
  END $
/*結束符置爲;*/
DELIMITER ;

見效果:

mysql> CALL proc3(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

示例2:添加leave控制語句

根據傳入的參數v_count向test1表插入指定數量的數據,當插入超過10條,結束。

/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc4;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc4(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:WHILE i<=v_count DO
      INSERT into test1 values (i);
      /*判斷i=10,離開循環a*/
      IF i=10 THEN
        LEAVE a;
      END IF;

      SET i=i+1;
    END WHILE;
  END $
/*結束符置爲;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 20 rows affected (0.00 sec)

mysql> CALL proc4(20);
Query OK, 1 row affected (0.02 sec)

mysql> SELECT * from test1;
+----+
| a  |
+----+
|  1 |
|  2 |
|  3 |
|  4 |
|  5 |
|  6 |
|  7 |
|  8 |
|  9 |
| 10 |
+----+
10 rows in set (0.00 sec)

示例3:添加iterate控制語句

根據傳入的參數v_count向test1表插入指定數量的數據,只插入偶數數據。

/*刪除test1表記錄*/
DELETE FROM test1;
/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc5;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc5(v_count int)
  BEGIN
    DECLARE i int DEFAULT 0;
    a:WHILE i<=v_count DO
      SET i=i+1;
      /*若是i不爲偶數,跳過本次循環*/
      IF i%2!=0 THEN
        ITERATE a;
      END IF;
      /*插入數據*/
      INSERT into test1 values (i);
    END WHILE;
  END $
/*結束符置爲;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 5 rows affected (0.00 sec)

mysql> CALL proc5(10);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+----+
| a  |
+----+
|  2 |
|  4 |
|  6 |
|  8 |
| 10 |
+----+
5 rows in set (0.00 sec)

示例4:嵌套循環

test2表有2個字段(a,b),寫一個存儲過程(2個參數:v_a_count,v_b_count),使用雙重循環插入數據,數據條件:a的範圍[1,v_a_count]、b的範圍[1,v_b_count]全部偶數的組合。

/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc8;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc8(v_a_count int,v_b_count int)
  BEGIN
    DECLARE v_a int DEFAULT 0;
    DECLARE v_b int DEFAULT 0;

    a:WHILE v_a<=v_a_count DO
      SET v_a=v_a+1;
      SET v_b=0;
      
      b:WHILE v_b<=v_b_count DO
      
        SET v_b=v_b+1;
        IF v_a%2!=0 THEN
          ITERATE a;
        END IF;

        IF v_b%2!=0 THEN
          ITERATE b;
        END IF;

        INSERT INTO test2 VALUES (v_a,v_b);

      END WHILE b;

    END WHILE a;
  END $
/*結束符置爲;*/
DELIMITER ;

代碼中故意將ITERATE a;放在內層循環中,主要讓你們看一下效果。

見效果:

mysql> DELETE FROM test2;
Query OK, 6 rows affected (0.00 sec)

mysql> CALL proc8(4,6);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test2;
+---+---+
| a | b |
+---+---+
| 2 | 2 |
| 2 | 4 |
| 2 | 6 |
| 4 | 2 |
| 4 | 4 |
| 4 | 6 |
+---+---+
6 rows in set (0.00 sec)

repeat循環

語法

[標籤:]repeat
循環體;
until 結束循環的條件 end repeat [標籤];

repeat循環相似於java中的do...while循環,無論如何,循環都會先執行一次,而後再判斷結束循環的條件,不知足結束條件,循環體繼續執行。這塊和while不一樣,while是先判斷條件是否成立再執行循環體。

示例1:無循環控制語句

根據傳入的參數v_count向test1表插入指定數量的數據。

/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc6;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc6(v_count int)
  BEGIN
    DECLARE i int DEFAULT 1;
    a:REPEAT
      INSERT into test1 values (i);
      SET i=i+1;
    UNTIL i>v_count END REPEAT;
  END $
/*結束符置爲;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 1 row affected (0.00 sec)

mysql> CALL proc6(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

repeat中iterateleave用法和while中相似,這塊的示例算是給你們留的做業,寫好的發在留言區,謝謝。

loop循環

語法

[標籤:]loop
循環體;
end loop [標籤];

loop至關於一個死循環,須要在循環體中使用iterate或者leave來控制循環的執行。

示例1:無循環控制語句

根據傳入的參數v_count向test1表插入指定數量的數據。

/*刪除存儲過程*/
DROP PROCEDURE IF EXISTS proc7;
/*聲明結束符爲$*/
DELIMITER $
/*建立存儲過程*/
CREATE PROCEDURE proc7(v_count int)
  BEGIN
    DECLARE i int DEFAULT 0;
    a:LOOP
      SET i=i+1;
      /*當i>v_count的時候退出循環*/
      IF i>v_count THEN
        LEAVE a;
      END IF;
      INSERT into test1 values (i);
    END LOOP a;
  END $
/*結束符置爲;*/
DELIMITER ;

見效果:

mysql> DELETE FROM test1;
Query OK, 5 rows affected (0.00 sec)

mysql> CALL proc7(5);
Query OK, 1 row affected (0.01 sec)

mysql> SELECT * from test1;
+---+
| a |
+---+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+---+
5 rows in set (0.00 sec)

loop中iterateleave用法和while中相似,這塊的示例算是給你們留的做業,寫好的發在留言區,謝謝。

總結

  1. 本文主要介紹了mysql中控制流語句的使用,請你們下去了多練習,熟練掌握
  2. if函數經常使用在select中
  3. case語句有2種寫法,主要用在select、begin end中,select中end後面能夠省略case,begin end中使用不能省略case
  4. if語句用在begin end中
  5. 3種循環體的使用,while相似於java中的while循環,repeat相似於java中的do while循環,loop相似於java中的死循環,都用於begin end中
  6. 循環中體中的控制依靠leaveiterateleave相似於java中的break能夠退出循環,iterate相似於java中的continue能夠結束本次循環

Mysql系列目錄

  1. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933257&idx=1&sn=0f0086a2465a2fcae13d3fea65064803&chksm=88621bb7bf1592a1ac94fe4107ba1ef26a0fa97e1bf9aea7279009d8bd240f1ef7d27aa10393&token=1876080189&lang=zh_CN#rd">第1篇:mysql基礎知識</a>
  2. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933270&idx=1&sn=409080e17352da2035b0bfdf63ccdfde&chksm=88621ba8bf1592beb2ef6106d6bf9f3eccd48d6814c7031f36e3c8be68821f17cf065129688c&token=1876080189&lang=zh_CN#rd"> 第2篇:詳解mysql數據類型(重點)</a>
  3. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933279&idx=1&sn=f8591b95362cb3c352d895b1289d665a&chksm=88621ba1bf1592b72a43a62e3f310695e8b87f17932d052145622c3edbb70ef8cb987849fc3e&token=516655478&lang=zh_CN#rd"> 第3篇:管理員必備技能(必須掌握)</a>
  4. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933289&idx=1&sn=c4f212c312ea86e08ad322caddd05e38&chksm=88621b97bf159281156ee3be510a1a15234531d2c97d66957e67377829ab23779809ea55bbde&token=1484565200&lang=zh_CN#rd"> 第4篇:DDL常見操做</a>
  5. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933296&idx=1&sn=1c56256d60c5847a944d87c8cfc9c14d&chksm=88621b8ebf159298b0789e2994d2aaf8b582effc7d8c1ba715deaca11c86a9dc8ac730878dc0&token=2000571846&lang=zh_CN#rd"> 第5篇:DML操做彙總(insert,update,delete)</a>
  6. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933300&idx=1&sn=bedef4d430dc76141e42e42ef6acfaa6&chksm=88621b8abf15929caae7904019c946a396885a33855ca465bacdd4187538005ebc3c116888f5&token=1814800041&lang=zh_CN#rd"> 第6篇:select查詢基礎篇</a>
  7. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933305&idx=1&sn=2c5ba0bea6fcdd57d86cecd63541f91a&chksm=88621b87bf1592915086c1e945119fcc95af6aa1127b90ef1b56b018083bfd787ad95efde918&token=1144227002&lang=zh_CN#rd"> 第7篇:玩轉select條件查詢,避免採坑</a>
  8. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933309&idx=1&sn=0f7dfec8bc70e67daa7159ee219325b8&chksm=88621b83bf1592951d949179061f39a1f4266b2879bc9a25af4da3b4b29f69ab1fcc595a462f&token=516674265&lang=zh_CN#rd"> 第8篇:詳解排序和分頁(order by & limit)</a>
  9. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933315&idx=1&sn=4abf2b34a53a85cbd4a3b9ee31fcd398&chksm=88621bfdbf1592eb6a5a13202588dde9068ac7e6391d8dbf3fde33647bf0e044839ba4228216&token=1937580929&lang=zh_CN#rd"> 第9篇:分組查詢詳解(group by & having)</a>
  10. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933321&idx=1&sn=110f6cacb90845bf2327fbcd7acd708c&chksm=88621bf7bf1592e1f1c0f2f01e40d4bd63a48d98daa4ba1157ecad4c6c6520d18b4b2c24c906&token=1096041061&lang=zh_CN#rd"> 第10篇:經常使用的幾十個函數詳解</a>
  11. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933325&idx=1&sn=33274227db275a3570e1e43ccdd4f49c&chksm=88621bf3bf1592e5b75f537e21961c4295fafb782dbf31c0c1cbf9e36f5f4ed44d31cdad68b3&token=1832579722&lang=zh_CN#rd"> 第11篇:深刻了解鏈接查詢及原理</a>
  12. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933342&idx=2&sn=2e41daa0926a9c32d5fddd23590391aa&chksm=88621be0bf1592f66904a184858df7c11129e8b545c7626b8b6c1fcc32d3dfdd9ab21aeda8e5&token=386795745&lang=zh_CN#rd"> 第12篇:子查詢</a>
  13. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933349&idx=1&sn=6e81f9046119cda43f8eb602d1139ef0&chksm=88621bdbbf1592cd9a20ec4715fe9f9459d079b641b04f607999c106cd52453d8c8508d939d7&token=386795745&lang=zh_CN#rd"> 第13篇:細說NULL致使的神坑,讓人防不勝防</a>
  14. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933355&idx=1&sn=b426ad28dfc2a64bba813df5b7c341a4&chksm=88621bd5bf1592c3c08e441398f699d0a4c2303a51519aac169447f22765cc613dfc3d991f8b&token=385335213&lang=zh_CN#rd"> 第14篇:詳解事務</a>
  15. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933370&idx=1&sn=4fe9b8e2aba766988c503737d34d9836&chksm=88621bc4bf1592d2b06d659884bf9881bd207a042ac36176f12808bd72f235e8e3404366259e&token=84059034&lang=zh_CN#rd"> 第15篇:詳解視圖</a>
  16. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933374&idx=1&sn=c294b6a69564a4c98d4c0cb29aeb9ac0&chksm=88621bc0bf1592d650752c44ca50540c1fa0c88c0a514019f1317559e13098de7dac37ddfc05&token=1531009350&lang=zh_CN#rd"> 第16篇:變量詳解</a>
  17. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933382&idx=1&sn=4cf80b4f50c80dcc8171d2128b47cf63&chksm=88621c38bf15952e193177a0ba3e03beeaeed996553ce6900f91518310332e99c915e8be2566&token=1341741305&lang=zh_CN#rd"> 第17篇:存儲過程&自定義函數詳解</a>
  18. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933388&idx=1&sn=59cb1d23845e45894bb72c1e2479f074&chksm=88621c32bf1595241573e4194912ca60a51eb8477f4b49492e26668c9bebc032e9d6672e7fdd&token=1832749573&lang=zh_CN#rd"> 第18篇:流程控制語句</a>
  19. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933392&idx=1&sn=ff29e380b42a0aa7cb1dc7659d745686&chksm=88621c2ebf1595380f99d9c4c89581638a27a5cf356de35d31aa9ae7ac17e63abe0e4adc813c&token=1479782197&lang=zh_CN#rd"> 第19篇:遊標詳解</a>
  20. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933396&idx=1&sn=b6cc5d5287bf43d94e6706fa217aa8cb&chksm=88621c2abf15953c3200c6d4d945ad70bdd2177f020f8e2229ae269153bbc8bf251af83e1135&token=1846211483&lang=zh_CN#rd"> 第20篇:異常捕獲及處理詳解</a>
  21. <a target="_blank" href="https://mp.weixin.qq.com/s?__biz=MzA5MTkxMDQ4MQ==&mid=2648933400&idx=1&sn=61af771f10342ee4956efea6749abd71&chksm=88621c26bf15953041a6bc65734edf788af711ff176ad36884fe6411e5c4cfd0bf967e0e33fc&token=877024264&lang=zh_CN#rd">第21篇:什麼是索引?</a>

mysql系列大概有20多篇,喜歡的請關注一下,歡迎你們加我微信itsoku或者留言交流mysql相關技術!

原文出處:https://www.cnblogs.com/itsoku123/p/11640021.html

相關文章
相關標籤/搜索