現象:
在開發的過程中,往往需要數字和字符串互轉。在轉換的過程中,可能需要把1編程00001,這樣的格式。實現這種樣子是有非常多的方法,本文主要提供一種自定義函數來實現
?
說明:
???????? 一般來說這種處理主要使用CONVERT或者CAST來實現即可。思路是先轉換為字符串然后在不上足夠數量的0,最后使用RIGHT函數,從右邊取出需要長度。
?
案例:
???????? 本例中使用AdventureWork數據庫作為例子。
首先,執行下面語句:
-- 查詢部門數據
SELECT DepartmentID , Name
FROM AdventureWorks . HumanResources . Department
?
結果如下:
?
然后,使用CAST將原來部門編號轉換成VARCHAR()字符串。接著加上固定數量的0,然后利用RIGHT函數,從右邊去除指定數量的字符串。
代碼如下:
-- 查詢部門數據并將數字根據位數補上 0
SELECT RIGHT( REPLICATE ( '0' , 5 )+ CAST ( DepartmentID AS varchar ( 10 )), 5 ) AS 'DepartmentID' , Name
FROM AdventureWorks . HumanResources . Department
ORDER BY DepartmentID
?
結果:
以上的是準備工作,現在開始編寫一個自定義函數來實現,此函數有兩個參數,第一個參數是要補0或者其他數目的個數,第二個是要轉換的數字。最后把結果以字符串方式返回:
?
函數代碼:
CREATE FUNCTION fnZero
(
??? @n INT ,
??? @i INT
)
RETURNS VARCHAR ( 125 )
AS
BEGIN
??? RETURN
??? (
??????? RIGHT( REPLICATE ( '0' , @n )+ CAST ( @i as varchar ( 125 )), @n )
??? )
END
?
使用例子:
-- 查詢部門數據并將數字根據位數補上 0
SELECT DepartmentID as 'DepartmentID' , dbo . fnZero ( 5 , DepartmentID ) as 'DepartmentID'
FROM AdventureWorks . HumanResources . Department
ORDER BY 1
注意,由于兩個列都是同名,所以ORDER BY 那里使用了1,而不是列名.
結果如下:
?
當然,也可以改進該函數,使得函數能滿足很多要求.這部分請讀者自己去研究了.
?
?
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
