sql下拆分字符串

来源:未知 责任编辑:责任编辑 发表时间:2014-01-20 07:54 点击:

--拆分字符卡
create FUNCTION s(@id varchar(20),@编号串 varchar(max))
RETURNS @tab table(ID varchar(20),编号 varchar(30))
begin
 declare @ipos int, @bh varchar(20);
 while 1>0
 begin
  set @ipos=Charindex(',',@编号串,1)
  if @ipos>0
   set @bh=substring(@编号串,1,@ipos-1)
  else
   set @bh=@编号串
  set @编号串=substring(@编号串,@ipos+1,len(@编号串))
  if LEN(@bh)>0
      begin
     insert into @tab(ID,编号)values(@id,@bh);
   end
  if isnull(@ipos,0)<1 break
 end
 return
end
 
--循环获取数据(存储过程版本)
alter proc c
as
begin
    create table #w
    (
      id varchar(20),
      name varchar(20)
    
    )
  declare @编号 varchar(max)
  declare @id varchar(max)
  select ROW_NUMBER() OVER(ORDER BY getdate()) AS RowNumber ,* into #T from ss
  declare @i int;
  set @i=1;
  while(@i<=(select count(*) from ss))
   begin
   set @编号=(select  name from #T where RowNumber=@i)
   set @id=(select  id from #T where RowNumber=@i)
   insert into #w select * from s(@id,@编号)
   set @i=@i+1
   end
   select * from #w
  drop table #T
  drop table #w
end
--exec c
 
--循环获取数据(函数版本) www.2cto.com

alter FUNCTION s1()
     RETURNS @tab table(ID varchar(20),编号 varchar(30))
begin
 begin
   declare @编号 varchar(max)
   declare @id varchar(max)
   declare @i int;
   set @i=1;
   while(@i<=(select count(*) from ss))
    begin
     set @编号=(
        select  name from 
        (
           select ROW_NUMBER() OVER(ORDER BY getdate()) AS RowNumber ,* from ss
        )a where a.RowNumber=@i
              )
     set @id=(
                 select  id from 
                 (
                    select ROW_NUMBER() OVER(ORDER BY getdate()) AS RowNumber ,* from ss
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • sql常见面试题
  • SQL SERVER 2005性能之跟踪
  • SQL编程(一)
  • LINUX上RMAN自动备份脚本
  • sql server面试题
  • 如何将多个SQL查询统计结果一次显示出来
  • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
  • SQL小技巧系列 --- 行转列合并
  • sql server 列转行
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1