第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

最有效的T-SQL方式將左邊的varchar填充到一定長度?

最有效的T-SQL方式將左邊的varchar填充到一定長度?

收到一只叮咚 2019-08-16 15:37:49
最有效的T-SQL方式將左邊的varchar填充到一定長度?相比之下說:REPLICATE(@padchar, @len - LEN(@str)) + @str
查看完整描述

3 回答

?
函數(shù)式編程

TA貢獻1807條經(jīng)驗 獲得超9個贊

無論您如何操作,這只是SQL的低效使用。

也許是這樣的

right('XXXXXXXXXXXX'+ rtrim(@str), @n)

其中X是您的填充字符,@ n是結(jié)果字符串中的字符數(shù)(假設(shè)您需要填充,因為您正在處理固定長度)。

但正如我所說,你應(yīng)該真的避免在你的數(shù)據(jù)庫中這樣做。


查看完整回答
反對 回復(fù) 2019-08-16
?
慕少森

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。


查看完整回答
反對 回復(fù) 2019-08-16
?
侃侃無極

TA貢獻2051條經(jīng)驗 獲得超10個贊

有幾個人提供了這個版本:

right('XXXXXXXXXXXX'+ @str, @n)

要小心,因為如果它長于n,它將截斷你的實際數(shù)據(jù)。


查看完整回答
反對 回復(fù) 2019-08-16
  • 3 回答
  • 0 關(guān)注
  • 589 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號