2

我有一个查询,我从数据库中提取支票号码。返回值必须始终为 9 个字符。大多数支票号码只有 6 个字符,所以我想在字符串前面加上 0,以确保它总是正好是 9 个字符。由于校验码的长度可能不同,因此每个校验码的 0 数量会有所不同。最有效的方法是什么?

4

1 回答 1

0

如果它们总是在 6 到 9 位之间,最简单(可能也是最好)的方法是使用 CASE。

SELECT CASE WHEN LEN(CHECK_NUM)= 6 THEN '000' WHEN LEN(CHECK_NUM) = 7 THEN '00' 
       WHEN 
       LEN(CHECK_NUM) = 8 THEN '0' ELSE '' END + CHECK_NUM 
FROM   TABLE 

编辑
如果原始值是数字(int),请尝试以下操作:

SELECT CASE WHEN LEN(CHECK_NUM)= 6 THEN '000' WHEN LEN(CHECK_NUM) = 7 THEN '00' 
       WHEN 
       LEN(CHECK_NUM) = 8 THEN '0' ELSE '' END + CAST(CHECK_NUM AS VARCHAR(9)) 
FROM   TABLE1 

看看这个SQL Fiddle

于 2013-09-04T13:50:03.497 回答