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

推荐订阅源

T
Tenable Blog
Last Week in AI
Last Week in AI
P
Proofpoint News Feed
Engineering at Meta
Engineering at Meta
H
Help Net Security
F
Fortinet All Blogs
MyScale Blog
MyScale Blog
宝玉的分享
宝玉的分享
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 司徒正美
量子位
N
Netflix TechBlog - Medium
Apple Machine Learning Research
Apple Machine Learning Research
小众软件
小众软件
Recorded Future
Recorded Future
博客园 - 三生石上(FineUI控件)
Vercel News
Vercel News
aimingoo的专栏
aimingoo的专栏
I
InfoQ
Microsoft Security Blog
Microsoft Security Blog
Scott Helme
Scott Helme
The Last Watchdog
The Last Watchdog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
IT之家
IT之家
AI
AI
WordPress大学
WordPress大学
Security Archives - TechRepublic
Security Archives - TechRepublic
Google Online Security Blog
Google Online Security Blog
U
Unit 42
V2EX - 技术
V2EX - 技术
MongoDB | Blog
MongoDB | Blog
Schneier on Security
Schneier on Security
博客园 - Franky
H
Heimdal Security Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Jina AI
Jina AI
W
WeLiveSecurity
P
Privacy & Cybersecurity Law Blog
Cloudbric
Cloudbric
B
Blog RSS Feed
N
News | PayPal Newsroom
S
Securelist
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
I
Intezer
Hacker News - Newest:
Hacker News - Newest: "LLM"
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
博客园_首页
罗磊的独立博客
H
Hackread – Cybersecurity News, Data Breaches, AI and More
雷峰网
雷峰网

博客园 - 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