日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

T-SQL使用案例——結果數據前面自動補0

系統 2067 0
原文: T-SQL使用案例——結果數據前面自動補0


現象:

在開發的過程中,往往需要數字和字符串互轉。在轉換的過程中,可能需要把1編程00001,這樣的格式。實現這種樣子是有非常多的方法,本文主要提供一種自定義函數來實現

?

說明:

???????? 一般來說這種處理主要使用CONVERT或者CAST來實現即可。思路是先轉換為字符串然后在不上足夠數量的0,最后使用RIGHT函數,從右邊取出需要長度。

?

案例:

???????? 本例中使用AdventureWork數據庫作為例子。

首先,執行下面語句:

-- 查詢部門數據

SELECT DepartmentID , Name

FROM AdventureWorks . HumanResources . Department

?

結果如下:

? T-SQL使用案例——結果數據前面自動補0

然后,使用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

?

結果:

T-SQL使用案例——結果數據前面自動補0

以上的是準備工作,現在開始編寫一個自定義函數來實現,此函數有兩個參數,第一個參數是要補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,而不是列名.

結果如下:

? T-SQL使用案例——結果數據前面自動補0

當然,也可以改進該函數,使得函數能滿足很多要求.這部分請讀者自己去研究了.

?

?

T-SQL使用案例——結果數據前面自動補0


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 庄浪县| 宁强县| 盐津县| 景东| 东光县| 桂林市| 临湘市| 厦门市| 大连市| 延安市| 商河县| 通州市| 清水县| 邳州市| 阳原县| 栾川县| 甘德县| 社旗县| 清水县| 南涧| 卢湾区| 郯城县| 南丹县| 富蕴县| 门源| 健康| 冀州市| 东乡族自治县| 仁布县| 彭水| 威信县| 上虞市| 巍山| 潍坊市| 阜平县| 天峻县| 大石桥市| 廊坊市| 莲花县| 明星| 南陵县|