Skip to content

Zeroplex 生活隨筆

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

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

標籤: MySQL

在 mysqldump 指定要匯出的條件

Posted on 2024 年 9 月 22 日2024 年 9 月 22 日 By 日落 在〈在 mysqldump 指定要匯出的條件〉中尚無留言

一般來說,mysqldump 會出 dbname.mytable 的語法大致如下:

mysqldump dbname mytable -u root -p

如果 table 中的資料太多,只想匯出較新的項目,如 id 大於特定數值,則可使用 --where:

mysqldump dbname mytable \
    --where 'id > 10000' \
    -u root -p

--where 使用時要注意引號,如果有字串時記得要 escape 掉

Tags:MariaDB, MySQL

MySQL 上的資料型態轉換

Posted on 2023 年 1 月 20 日2023 年 1 月 20 日 By 日落 在〈MySQL 上的資料型態轉換〉中尚無留言

MySQL 上可用 cast() 做資料型態轉換,不過 data type 的 reserve word 和一般 CREATE TABLE 時用的不太一樣。詳細參考 MySQL cast funtion 的說明。

轉數字:

  • SIGNED、UNSIGNED:相當於 `BIGINT`
  • FLOAT(N)、DOUBLE、REAL:浮點數,FLOAT 要指定精確度,用 DOUBLE 比較快
  • DECIMAL[M, D]:要指定資料長度

轉字串:

  • CHAR[N]、NCHAR[N]:要指定字串長度
  • TEXT、LONGTEXT:不支援,只能使用前一項的 reserve word

若資料不是要在 DBMS runtime 處理,而是要輸出以後由其他程式語言處理的話,是可以考慮直接轉 JSON 型態。但若要在 DBMS 裡面使用的話,還是乖乖轉支援的資料型態比較不會出錯。

Tags:MySQL

MySQL 變數未指定資料型態導致非預期行為

Posted on 2022 年 12 月 24 日2022 年 12 月 24 日 By 日落 在〈MySQL 變數未指定資料型態導致非預期行為〉中尚無留言

發現如果 MySQL 中的變數未指定資料型態,會出現一些很雷的行為。

這邊用 JSON 型態:

select json_array(
   100,
   JSON_ARRAY(1, 2)
);
# 輸出:  [100, [1, 2]]

先除存到 @list 以後在讀取,資料型態就會亂掉:

SET @list = json_array(1, 2);
select json_array(
   100,
   @list
);
# 輸出:  [100, "[1, 2]"]

若需要用到變數,建議先宣告變數型態:

DECLARE list JSON;
SET list = json_array(1, 2);
Tags:MySQL

MySQL 8.0.31 的 function 的語法與官方文件不符

Posted on 2022 年 12 月 20 日2022 年 12 月 20 日 By 日落 在〈MySQL 8.0.31 的 function 的語法與官方文件不符〉中尚無留言

用以下的 SQL 來建立新的 function:

CREATE FUNCTION myfunc(IN str TEXT) RETURNS TEXT RETURN '123';

執行以後會出現錯誤訊息:

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IN str TEXT) returns TEXT return '123'' at line 1

將 function parameter 中的 IN 刪除以後就不會再出現錯誤訊息。

問題是按照 MySQL 官方文件中 create function statements 中的說明,IN 參數是 optional 的,可加可不加,但實際執行時加上 IN 就會出現上面的錯誤。

所以問題來了,是 MySQL 沒有按照文件中的規範實作?還是文件並沒有跟著 MySQL 的實作更新?

Tags:MySQL

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

文章分頁

1 2 ... 6 下一頁

其他

關於我  (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 國際 授權條款授權.