博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[转载]实现PadLeft的SQL脚本
阅读量:4977 次
发布时间:2019-06-12

本文共 1014 字,大约阅读时间需要 3 分钟。

C#有个函数PadLeft函数:右对齐此实例中的字符,在左边用空格或指定的 Unicode 字符填充以达到指定的总长度。SQL中我们也可能有这种需求.比如字符串希望保持7位不足7位前面用0补全. 

  1. 1 -------- 0000001  
  2. 109 ------ 0000109  
  3. 0987 ----- 0000987   

解决方案1:使用RIGHT,REPLICATE函数 

  1. CREATE FUNCTION dbo.PadLeft 
  2. (   
  3. @len int,  
  4. @string VARCHAR(max),  
  5. @padchar CHAR(1))  
  6. RETURNS VARCHAR(255) AS  
  7. BEGIN  
  8. RETURN RIGHT(  
  9.                 REPLICATE(@padchar, @len) + CONVERT (VARCHAR(MAX), @string),  
  10.                 @len  
  11.              )  
  12. END  
  13. GO  

解决方案2:使用REPLACESPACE函数 

  1. CREATE FUNCTION dbo.PadLeft 
  2. (   
  3. @len int,  
  4. @string VARCHAR(max),  
  5. @padchar CHAR(1))  
  6. RETURNS VARCHAR(255) AS  
  7. BEGIN  
  8. RETURN LTRIM(RTRIM(  
  9.                 CASE  
  10.                 WHEN LEN(@string) < @len  
  11.                 THEN REPLACE(SPACE(@len - LEN(@string)), ' ', @padchar) + @string  
  12.                 ELSE @string  
  13.                 END  
  14.                   )  
  15.              )  
  16. END  
  17. GO  

解决方案3:使用REPLICATE和ISNULL函数 

  1. CREATE FUNCTION dbo.PadLeft  
  2. (  
  3.     @len int,  
  4.     @string VARCHAR(max),  
  5.     @padchar CHAR(1)  
  6. )  
  7. RETURNS VARCHAR(max)  
  8. AS  
  9. BEGIN  
  10. RETURN ISNULL(REPLICATE(@padchar, @len - LEN(@string)), '')  
  11.        + CAST(@string AS VARCHAR)  
  12. END  
  13. GO  

调用示例: 

  1. select dbo.PadLeft(7,'123','0')  --0000123  

原载: 链接:

转载于:https://www.cnblogs.com/litsword/archive/2012/02/10/2345565.html

你可能感兴趣的文章