3 回答

TA貢獻1807條經(jīng)驗 獲得超9個贊
無論您如何操作,這只是SQL的低效使用。
也許是這樣的
right('XXXXXXXXXXXX'+ rtrim(@str), @n)
其中X是您的填充字符,@ n是結(jié)果字符串中的字符數(shù)(假設(shè)您需要填充,因為您正在處理固定長度)。
但正如我所說,你應(yīng)該真的避免在你的數(shù)據(jù)庫中這樣做。

TA貢獻2019條經(jīng)驗 獲得超9個贊
我知道這最初是在2008年被問到的,但是SQL Server 2012引入了一些新的功能.FORMAT功能簡化了左邊的填充。它還會為您執(zhí)行轉(zhuǎn)換:
declare @n as int = 2select FORMAT(@n, 'd10') as padWithZeros
更新:
我想自己測試FORMAT功能的實際效率。我很驚訝地發(fā)現(xiàn),與AlexCuse的原始答案相比,效率并不是很好。雖然我發(fā)現(xiàn)FORMAT功能更清潔,但在執(zhí)行時間方面效率不高。我使用的Tally表有64,000條記錄。榮譽對馬丁·史密斯的指出了執(zhí)行時間效率。
SET STATISTICS TIME ONselect FORMAT(N, 'd10') as padWithZeros from TallySET STATISTICS TIME OFF
SQL Server執(zhí)行時間:CPU時間= 2157毫秒,已用時間= 2696毫秒。
SET STATISTICS TIME ONselect right('0000000000'+ rtrim(cast(N as varchar(5))), 10) from TallySET STATISTICS TIME OFF
SQL Server執(zhí)行時間:
CPU時間= 31 ms,經(jīng)過時間= 235 ms。

TA貢獻2051條經(jīng)驗 獲得超10個贊
有幾個人提供了這個版本:
right('XXXXXXXXXXXX'+ @str, @n)
要小心,因為如果它長于n,它將截斷你的實際數(shù)據(jù)。
- 3 回答
- 0 關(guān)注
- 589 瀏覽
添加回答
舉報