项目经验之: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
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
青华木园
标签:
SQL asp.net
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架