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

首頁 > 數據庫 > SQL Server > 正文

MS SQL Server存儲過程參數的隱式類型轉換

2024-08-31 00:51:50
字體:
來源:轉載
供稿:網友

Microsoft SQL Server 2000數據表的列和存儲過程的參數都是有類型的,但我發現在寫存儲過程時很多參數類型是可以“混用”的,比如,下面的存儲過程:

 

/**//*
 Name :    Stp_TestDifferentParaType_INT
 Function :   測試不同參數類型對存儲過程的影響
 Author :   Waxdoll Cheung
 Date :    2005-04-07
*/
 
CREATE PROCEDURE dbo.Stp_TestDifferentParaType_INT
  -- 統計年月
  @TongJiNianYue INT
AS
 SELECT [FM_產品登記].* FROM [FM_產品登記] WHERE (所屬年份 = @TongJiNianYue) 
 
 RETURN
GO
 
 

和下面的存儲過程:


/**//*
 Name :    Stp_TestDifferentParaType_CHAR
 Function :   測試不同參數類型對存儲過程的影響
 Author :   Waxdoll Cheung
 Date :    2005-04-07
*/
 
CREATE PROCEDURE dbo.Stp_TestDifferentParaType_CHAR
  -- 統計年月
  @TongJiNianYue CHAR(4)
AS
 SELECT [FM_產品登記].* FROM [FM_產品登記] WHERE (所屬年份 = @TongJiNianYue) 
 
 RETURN
GO
 
 

在測試存儲過程時輸出的結果是一樣的,而數據列是有類型的——CHAR(4),
為什么呢?應該是存儲過程在執行時對參數進行了隱式類型轉換。

但寫存儲過程時確定參數的類型時應該注意:
1、應該盡量使用和數據列類型相同的數據類型,減少運行是的隱式類型轉換;
2、不是所有類型都可以進行隱式類型轉換的,如果使用不同的數據類型,很可能會發生錯誤: 
 圖:Microsoft SQL Server數據類型轉換圖

另外,SQL Server自定義函數的參數也有類似情況。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 万年县| 凭祥市| 壶关县| 明溪县| 荥经县| 潞西市| 赤城县| 湘乡市| 甘南县| 将乐县| 会东县| 榆林市| 海口市| 双流县| 翁牛特旗| 丹棱县| 凯里市| 南川市| 麻江县| 商丘市| 迁安市| 福贡县| 根河市| 耒阳市| 贺兰县| 绿春县| 锦州市| 阜南县| 海晏县| 阿瓦提县| 将乐县| 辽阳市| 肃宁县| 冀州市| 沿河| 桐梓县| 新河县| 辉县市| 马龙县| 楚雄市| 武鸣县|