SQL SERVER中SELECT和SET賦值相同點與不同點

来源:https://www.cnblogs.com/markkang/archive/2019/12/01/11965732.html
-Advertisement-
Play Games

SELECT和SET在SQL SERVER中都可以用來對變數進行賦值,但其用法和效果在一些細節上有些不同。 1. 在對變數賦值方面,SET是ANSI標準的賦值方式,SELECT則不是。這也是SET方式被推薦使用的原因之一。 2. SELECT可以一次對多個變數進行賦值,而SET一次只能對一個變數賦值 ...


SELECT和SET在SQL SERVER中都可以用來對變數進行賦值,但其用法和效果在一些細節上有些不同。

1. 在對變數賦值方面,SET是ANSI標準的賦值方式,SELECT則不是。這也是SET方式被推薦使用的原因之一。

2. SELECT可以一次對多個變數進行賦值,而SET一次只能對一個變數賦值。

DECLARE @NAME NVARCHAR(128), @AGE INT;
SET @NAME = N'小明';
SET @AGE=18;
PRINT @NAME;
PRINT @AGE;
GO
DECLARE @NAME NVARCHAR(128), @AGE INT; SELECT @NAME = N'小明',@AGE=18; PRINT @NAME; PRINT @AGE;

3.當使用子查詢給變數賦值時,則要求子查詢必須是標量子查詢(即子查詢得到結果是一個數據或者一行一列),不能返回多個值,否則會報錯。

1)但要註意的是,如果在SELECT查詢語句中給變數賦值的時候,查詢語句返回記錄的多少都不會產生錯誤,變數所得的值是查詢語句最後一行的記錄的相應值。

2)如果查詢結果沒有返回記錄,也就是說返回為NULL值時,將整個子查詢進行賦值的方式,SET和SELECT都會設置為NULL,而在SELECT查詢語句中賦值,變數會保持為初始值不受影響。

IF (OBJECT_ID('tempdb..#temp') is not null)
BEGIN
    DROP TABLE #temp;
END
ELSE
BEGIN
    CREATE TABLE #temp(
    [Name] NVARCHAR(128) ,
    AGE INT
    )
END
GO
INSERT INTO #temp([Name],AGE) VALUES(N'小明',18)
INSERT INTO #temp([Name],AGE) VALUES(N'小張',19)
INSERT INTO #temp([Name],AGE) VALUES(N'小王',17)
GO
DECLARE @NAME1 NVARCHAR(128), @AGE1 INT,@NAME2 NVARCHAR(128), @AGE2 INT;
SET @NAME1=(SELECT TOP 1 [NAME] FROM #temp);    --SET標量在查詢賦值
SELECT @AGE1=(SELECT TOP 1 AGE FROM #temp);        --SELECT標量在查詢賦值
SELECT @NAME2=[NAME],@AGE2=[AGE] FROM #temp;    --SELECT查詢語句中賦值
PRINT @NAME1; --正確運行,顯示結果:小明
PRINT @AGE1;  --正確運行,顯示結果:18
PRINT @NAME2; --正確運行,顯示結果:小王
PRINT @AGE2;  --正確運行,顯示結果:17

GO

DECLARE @NAME1 NVARCHAR(128), @AGE1 INT,@NAME2 NVARCHAR(128), @AGE2 INT;
SELECT @NAME1=N'初始名字',@AGE1=0,@NAME2=N'初始名字',@AGE2=0; --初始化各變數值
SET @NAME1=(SELECT TOP 1 [NAME] FROM #temp WHERE 1>1);    --SET標量在查詢賦值
SELECT @AGE1=(SELECT TOP 1 AGE FROM #temp WHERE 1>1);        --SELECT標量在查詢賦值
SELECT @NAME2=[NAME],@AGE2=[AGE] FROM #temp WHERE 1>1;    --SELECT查詢語句中賦值
PRINT @NAME1; --正確運行,實際值:NULL, 顯示結果:(空白)
PRINT @AGE1;  --正確運行,實際值:NULL, 顯示結果:(空白)
PRINT @NAME2; --正確運行,實際和顯示值:初始名字
PRINT @AGE2;  --正確運行,實際和顯示值:0
GO

 

 那麼我們該如何選擇使用哪種方式:

1. 因SET作為ANSI的標準,因此其是推薦用法。

2. 在不考慮標準的情況下,如果涉及到對多個變數賦值,為了少寫代碼或者獲取多個全局變數的值時,請考慮使用SELECT,一是因為簡便,二是一些全局變數會在在第二句執行時值發生變化。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近要使用到 alluxio,發現網上還是有一些文檔很是不錯,現在通過這篇文章進行索引一下,進行備忘: https://edgedef.com/2017/08/17/alluxio-%E5%B0%8F%E8%B0%83/ (以為網友關於 alluxio的調研) https://www2.eecs.b ...
  • 在dlib以及face_recognition通過pip安裝成功之後(如何通過pip進行安裝,在博主的上一篇隨筆中有提及),在pycharm中無法導入。 ...
  • 近些年機器視覺應用一直是個很火的方向,想象一下機器如果能長上“眼睛”,是不是就可以做一些人類才能做的事情,因此機器視覺是人工智慧實現的一個重要基礎。痞子衡當年碩士畢業論文課題就是工業相機圖像處理相關的,算是機器視覺系統的前端核心。遙想十年以前,想要從事機器視覺系統的開發一直是比較複雜的,需要開發者有... ...
  • 如圖,這個是看視頻時,最後的作業,除了客戶端未使用select實現外,其它的要求都有簡單實現。 服務端代碼如下: 客戶端代碼還是之前的版本,沒有使用select實現: ...
  • 最近,在Medium上出現了一個採訪問題:如何向奶奶解釋SQL和NoSQL之間的區別。我認為作者使用自己的結構化家譜來比較sql和nosql之間的差異。寫作非常好,但是有點尷尬。面試官沒有時間聽你的話。我個人認為sql和nosql之間的區別消失了。一兩個句子無法概括,更不用說告訴奶奶了,因此,如果您 ...
  • 資料庫 1、創建資料庫 2、查看資料庫 3、刪除資料庫 表 1、創建表 2、刪除表 3、重命名錶 列 1、添加列 2、刪除列 3、重命名列 約束 1、主鍵 視圖 1、創建視圖 2、刪除視圖 存儲過程 1、創建存儲過程 2、刪除存儲過程 3、執行存儲過程 4、重命名存儲過程 5、帶有輸出參數的存儲過程 ...
  • 存儲過程(特定功能的SQL語句集) 一組為了完成特定功能的SQL語句集,存儲在資料庫中,經過第一次編譯後再次調用不需要編譯,用戶通過指定存儲過程的名字並給出參數(如果該存儲過程帶有參數)來執行它。存儲過程是資料庫中一個重要對象。 1.創建存儲過程: create procedure 存儲過程名稱 ( ...
  • --創建資料庫使用預設的方式 create database 資料庫名稱 --創建一個完整的資料庫,帶有主文件和日誌文件 create database 資料庫名稱 --邏輯名稱 on primary( name='資料庫名稱', --物理名稱 filename='d:\名字.mdf', size= ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...