Skip to content

Zeroplex 生活隨筆

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

標籤: MSSQL

SQL Server 避免中文亂碼 (使用 Unicode)

Posted on 2021 年 12 月 23 日2021 年 12 月 23 日 By 日落 在〈SQL Server 避免中文亂碼 (使用 Unicode)〉中尚無留言

在 SQL server 中宣告變數為 varchar,雖然可以儲存字串,但是中文會變成亂碼。若要讓 SQL Server 可以處理多國語言的話,要記得將變數型態設定為 nvarchar:

DECLARE @str varchar(MAX);   -- 儲存一般文字

DECLARE @multibytes nvarchar(MAX);  -- 支援 unicode

另外,要設定 multibytes 字串時,記得要在引號前面加上「N」來表示字串類型:

@str = 'Hello World';   -- 一般字串

@multibytes = N'支援 multibytes 文字';  -- 引號前要加上 N

參考資料:nchar 和 nvarchar (Transact-SQL)

Tags:MSSQL

將 SQL Server 查詢結果存入變數 (local variable)

Posted on 2021 年 12 月 22 日2021 年 12 月 22 日 By 日落 在〈將 SQL Server 查詢結果存入變數 (local variable)〉中尚無留言

SQL Server 的語法,可將查詢結果存入 local variable 以便供下一個 query 使用。

作法是在 SELECT 時指定欄位要存數的變數名稱:

SELECT 
    @userid = uid
FROM users
WHERE mail = '....'

SQL Server 有區分資料型態,所以使用變數之前需要先宣告。假設這邊的 user ID 是一個長度小於 200 的字串,那就需要先宣告變數型態再使用變數:

DECLARE @userid varchar(200);

SELECT 
    @userid = uid
FROM users
WHERE mail = '....';

參考資料:SELECT @local_variable (Transact-SQL) – Microsoft Docs

Tags:MSSQL

SQL Server 宣告 (declare) 長字串變數

Posted on 2021 年 12 月 17 日2021 年 12 月 17 日 By 日落 在〈SQL Server 宣告 (declare) 長字串變數〉中尚無留言

若需要動態在 SQL Server 上組 SQL 語句,則必須宣告字串型態的變數 (variable) 供暫存:

DECLARE @query varchar(200)
SET @query = 'SELECT id, mail from user where id in (....)

但若無法預測 where in 語句就很難做變數宣告。

好險 SQL Server 有 reserve word 可以直接使用當下執行環境中的最大值:MAX,所以在無法預測字串長度的狀況下,可以將宣告改寫成:

DECLARE @query varchar(MAX)

按照 SQL Server 官方文件的說明,使用 MAX 的話,字串長度可以到 2^31-1,因此也必須小心使用,以免把機器給燒了。

相關資料:Declare Variable for a Query String

Tags:MSSQL

文章導覽

1 2 3 下一頁

其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

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


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