Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

MySQL 的 session variable vs local variable

Posted on 2022 年 12 月 16 日2022 年 12 月 16 日 By 日落 在〈MySQL 的 session variable vs local variable〉中尚無留言

使用變數的方式主要有二種,一是使用在變數名稱地一個字元加上 @ ,二是使用 DECLARE 宣告再 SET。

要注意的是 @ 開頭的變數 scope 為整個 session,也就是在不同 function / store procedure 都可以讀取數值、設定數值。如以下範例:

DELIMITER ;;
CREATE FUNCTION hello() RETURNS text
BEGIN
    SET @str = 'hello';
    RETURN @str;
END ;;
DELIMITER ;

DELIMITER ;;
CREATE FUNCTION world() RETURNS text
BEGIN
    SET @str = 'world';
    SET @str = CONCAT(hello(), ' ', @str);
    RETURN @str;
END ;;
DELIMITER ;

SELECT world() as result;

因為會讀、寫到同一個變數,所以輸出會是 hello hello。


若使用 DECLARE 宣告變數,則開變數的 scope 僅在 loop、function、store procedure 中才有效。相同的範例,改使用 DECLARE :

DELIMITER ;;
CREATE FUNCTION hello() RETURNS TEXT
BEGIN
    DECLARE str TEXT;
    SET str = 'hello';
    RETURN str;
END ;;
DELIMITER ;

DELIMITER ;;
CREATE FUNCTION world() RETURNS TEXT
BEGIN
    DECLARE str text;
    SET str = 'world';
    SET str = CONCAT(hello(), ' ', str);
    RETURN str;
END ;;
DELIMITER ;

SELECT world() AS result;

輸出結果為 hello world。

Tags:MySQL

文章導覽

Previous Post: 透過 restic 做差異性備份
Next Post: MySQL 8.0.31 的 function 的語法與官方文件不符

發佈留言 取消回覆

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *


其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.