项目经验之:SQL一些简单问题中可以使用的技巧

复制代码
 1 
 2 ------------------------------------------------------
 3 DECLARE @str varchar(500)
 4 SET @str='aaa,bbbx,eee,vv'
 5 SELECT LEN(REPLACE(@str,',',',,'))- LEN(@str)
 6 
 7 
 8 ------------------------------------------------------
 9 DECLARE @b BIT
10  SET @b=0
11 SELECT SUBSTRING(N'否是',@b+1,1)
12 
13 ------------------------------------------------------
14 DECLARE @ids varchar(50)
15 SET @ids='1,3'
16 SELECT * FROM UserInfo WHERE CHARINDEX(','+RTRIM(id) +',' , ','+@ids+',')>0 --考滤一下,这里为什么要在字串及ID前后加上逗号
17 ------------------------------------------------------
18 SELECT * INTO t1 FROM UserInfo WHERE 1=0
19 
20 
21 create function f_split(@str varchar(8000),@StrSeprate varchar(10))
22 returns @temp table(a varchar(100))
23 as 
24 begin
25     declare @i int
26     set @str=rtrim(ltrim(@SourceSql))
27     set @i=charindex(@StrSeprate,@str)
28     while @i>=1
29     begin
30         insert @temp values(left(@str,@i-1))
31         set @str=substring(@str,@i+1,len(@str)-@i--当然,这里您也可以改写为STUFF,可以自己试着改写一下
32         set @i=charindex(@StrSeprate,@str)
33     end
34     if @SourceSql<>'\'
35        insert @temp values(@str)
36     return 
37 end
38 
39 --利用创建临时表生成连续ID.
40 SELECT *,IDENTITY(INT) NID INTO #t FROM tb
41 
42  
43 
44 select * from dbo.f_split('A:B:C:D:E',':')
45 
复制代码

 

posted @   GIS发展  阅读(330)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示