惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

美团技术团队
D
DataBreaches.Net
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
D
Docker
N
Netflix TechBlog - Medium
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
C
Check Point Blog
腾讯CDC
Stack Overflow Blog
Stack Overflow Blog
V
Visual Studio Blog
IT之家
IT之家
月光博客
月光博客
U
Unit 42
K
Kaspersky official blog
T
Threatpost
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
GbyAI
GbyAI
P
Proofpoint News Feed
Last Week in AI
Last Week in AI
云风的 BLOG
云风的 BLOG
酷 壳 – CoolShell
酷 壳 – CoolShell
I
InfoQ
Engineering at Meta
Engineering at Meta
Recorded Future
Recorded Future
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
S
Security @ Cisco Blogs
MyScale Blog
MyScale Blog
大猫的无限游戏
大猫的无限游戏
Security Archives - TechRepublic
Security Archives - TechRepublic
Webroot Blog
Webroot Blog
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Schneier on Security
S
Secure Thoughts
The Register - Security
The Register - Security
B
Blog RSS Feed
The Last Watchdog
The Last Watchdog
P
Palo Alto Networks Blog
爱范儿
爱范儿
B
Blog
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
N
News and Events Feed by Topic
阮一峰的网络日志
阮一峰的网络日志
L
LINUX DO - 热门话题
C
Cisco Blogs
Spread Privacy
Spread Privacy
F
Full Disclosure
博客园 - 聂微东
T
The Blog of Author Tim Ferriss

博客园 - litsword

[转]IDENT_CURRENT、SCOPE_IDENTITY、@@IDENTITY 差異對照表 [转贴]TFS Power Tools–September 2010 Release SQL 中使用正则表达式过滤字母或数字 [转载]记不住ASP.NET页面生命周期的苦恼 Split Full Name as First and Last HTML 合并单元格示例 动态加载配置文件 Useful SQL script 在Update 和 Delete语句中使用 Inner Join SQL游标遍历时的变量赋值 SQL Date Time format SCOPE_IDENTITY、IDENT_CURRENT 和 @@IDENTITY 的区别 Union合并数组(去掉重复的项目) Winform 版本信息 Sql语句 生日提醒 事件的定义 【原创】RSS开发心得小结 SQL数据类型nchar,char,varchar与nvarchar区别 JavaScript里面三个等号和两个等号的区别
[转载]实现PadLeft的SQL脚本
litsword · 2012-02-10 · via 博客园 - litsword

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  

原载:IT智库网 链接:http://www.it118.org/specials/c9fba99e-4401-49cf-8256-ac3c1a34c0d9/a483105c-9912-4ef6-92e8-091a28510944.htm