广告
返回顶部
首页 > 资讯 > 数据库 >MS SQL 拆分逗号并检索字段
  • 396
分享到

MS SQL 拆分逗号并检索字段

2024-04-02 19:04:59 396人浏览 泡泡鱼
摘要

create table curtest (djbh varchar(20) primary key,sales varcha

create table curtest (djbh varchar(20) primary key,sales varchar(20))
Go
insert curtest
select 'A1','01,02,03' uNIOn all           --创建表并插入记录
select 'A2','01,02'  union all
select 'A3','02,03'  union all
select 'A4','02,03,04'  
go

declare cur_test cursor for select * from curtest    --声明游标
declare @djbh varchar(20)                            --定义变量单据编号
declare @sales varchar(20)                            --定义变量销售
declare @star int,@len int,@dhwz int                -- 定义变量开始,长度,逗号位置
open cur_test                                        --打开游标
fetch next from cur_test into @djbh,@sales            --获取第一条记录
while(@@FETCH_STATUS=0)                                --根据返回状态确认执行结果。0代表成功
begin
set @star=1                                            --对开始位置赋值1
set @dhwz=CHARINDEX(',',@sales,@star)                --获取第一个逗号位置
set @len=LEN(@sales)                                --获取字段长度
while(@star<=@LEN)                                    --循环条件,开始位置小于字段长度
begin                                            
select @djbh,substring(@sales,@star,@dhwz-@star)        --获取逗号前字符 
set @star=@dhwz+1                                        --每次循环,将上次逗号位置+1作为下次开始位置
set @dhwz=CHARINDEX(',',@sales,@star)                   --以上次逗号位置+1作为本次开始位置,检索下一个逗号位置
if(@dhwz=0)                                                --判断,当检索不到逗号(即返回值为0,并且已到达最后一个逗号)
begin
select @djbh,SUBSTRING(@sales,@star,(@len-@star)+1)     --最后一个逗号后字符,以上一次逗号位置+1开始,长度为字段总长度减开始位置+1
break                                                    --跳出循环    
end    
end
fetch next from cur_test into @djbh,@sales              --读取下一条记录,并重新开始执行循环(拆分并检索逗号分割字符)
end
close cur_test

MS SQL 拆分逗号并检索字段

MS SQL 拆分逗号并检索字段






您可能感兴趣的文档:

--结束END--

本文标题: MS SQL 拆分逗号并检索字段

本文链接: https://www.lsjlt.com/news/36341.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作