国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

基于SQL中SET與SELECT賦值的區別詳解

2024-07-24 12:40:47
字體:
來源:轉載
供稿:網友
最近的項目寫的SQL比較多,經常會用到對變量賦值,而我使用SET和SELECT都會達到效果。 那就有些迷惑,這兩者有什么區別呢?什么時候哪該哪個呢? 經過網上的查詢,及個人練習,總結兩者有以下幾點主要區別: 假定有設定變量: 復制代碼 代碼如下:     DECLARE @VAR1 VARCHAR(1)  DECLARE @VAR2 VARCHAR(2)      1、SELECT可以在一條語句里對多個變量同時賦值,而SET只能一次對一個變量賦值,如下: 復制代碼 代碼如下:     SELECT @VAR1='Y',@VAR2='N' -- 而SET要達到同樣的效果,需要: SET @VAR1='Y' SET @VAR2='N' /* 說到這個,SQL內置的變量:@@ERROR 和 @@ROWCOUNT必須要在一句SQL語句中捕獲。如果用set分兩句來獲取它們,將獲取不完整,這時就應該用select來獲取值。 */     2、表達式返回多個值時,用SET將會出錯,而SELECT將取最后一個值,如下: 復制代碼 代碼如下:     ----以下假定Permission表有多個IsRight記錄  SELECT @VAR1 = IsRight FROM Permission --將取最后一個值    SET @VAR1 = IsRight FROM Permission --將報錯      3、表達式無返回值時,用SET將置變量值為NULL,用SELECT交保持變量值,如下: 復制代碼 代碼如下:     ----以下假定Permission記錄為空  SET @VAR1 = '初始值'     SELECT @VAR1 = IsRight FROM Permission --此時@VAR1為'初始值'    SET @VAR1 = (SELECT IsRight FROM Permission) --此時@VAR1為NULL      4、使用標量子查詢時,如果無返回值,SET和SELECT一樣,都將置為NULL,如下: 復制代碼 代碼如下:     ----以下假定Permission記錄為空  SET @VAR1 = '初始值'   SELECT @VAR1 =(SELECT IsRight FROM Permission ) --此時@VAR1為NULL    SET @VAR1 = ( SELECT IsRight FROM Permission) --此時@VAR1為NULL 
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 中牟县| 康乐县| 大厂| 拉萨市| 克什克腾旗| 大丰市| 繁峙县| 叶城县| 高安市| 淳化县| 丘北县| 普宁市| 建始县| 烟台市| 明水县| 西城区| 凤翔县| 买车| 辰溪县| 镶黄旗| 大方县| 宁化县| 股票| 莆田市| 吴川市| 平武县| 福海县| 灯塔市| 射阳县| 科技| 长沙县| 霞浦县| 辉南县| 花莲县| 黑水县| 阳原县| 自贡市| 修水县| 宜宾县| 尼勒克县| 安化县|