目的:
把数据一条一条地插入,发现重复的执行UPDATE,不重复的插入。
建立如下的存储过程:
CREATE PROCEDURE ss
as
begin
declare @count [nvarchar] (20) 
declare cur_custer cursor
for  
select [保单号] from ss_temp
print '开始执行'
open cur_custer
fetch next from cur_custer into @count
while(@@fetch_status=0) --循环开始
begin
if  EXISTS(select 业务实收表.保单号 from 业务实收表 join ss_temp on 业务实收表.保单号=ss_temp.保单号 where 业务实收表.保单号=@count)
begin
Exec('update 业务实收表 set 财务结清日期=aa.财务结清日期,业务实收表.电子收据保费=业务实收表.电子收据保费+aa.电子收据保费 from ss_temp aa where aa.保单号=业务实收表.保单号 and aa.保单号='+@count)
print '更新'
end
else
begin
Exec('insert 业务实收表 select * from ss_temp where ss_temp.保单号='+@count)
print '插入'
print 'test'
end
fetch next from cur_custer into @count
end
print '结束'
close cur_custer --关闭游标
deallocate cur_custer--释放资源
end
GO调用这个存储过程,查询分析器的结果只显示“开始执行”和“结束”两个,也就是中间的循环根本没有执行,哪位高人帮我看一下是哪里错了,造成这个存储过程没有执行,谢谢!

解决方案 »

  1.   

    CREATE PROCEDURE ss
    as
    begin
    print '开始执行'
    declare @count [nvarchar] (20) 
    declare cur_custer cursor
    for  
    select [保单号] from ss_tempopen cur_custer
    fetch next from cur_custer into @count
    while(@@fetch_status=0)    --循环开始
    begin    
    if  EXISTS(select 业务实收表.保单号 from 业务实收表 join ss_temp on 业务实收表.保单号=ss_temp.保单号 where 业务实收表.保单号=@count)
    begin
        Exec('update 业务实收表 set 财务结清日期=aa.财务结清日期,业务实收表.电子收据保费=业务实收表.电子收据保费+aa.电子收据保费 from ss_temp aa where aa.保单号=业务实收表.保单号 and aa.保单号='+@count)
        print '更新'
    end
    else
        begin
            Exec('insert 业务实收表 select * from ss_temp where ss_temp.保单号='+@count)
            print '插入'
        print 'test'
        end
    fetch next from cur_custer into @count
    endclose cur_custer    --关闭游标
    deallocate cur_custer--释放资源
    print '结束'
    end
    GO
    drop proc ss
      

  2.   

    open cur_custer 
    fetch next from cur_custer into @count 
    print @@fetch_status  --- 看看打印什么东西 
    while(@@fetch_status=0)    --循环开始 
    begin  
      

  3.   

    确定 是否有表 ss_temp ?表是否有 [保单号] 列?
    删除ss_temp后的空格,是不是有非法字符
      

  4.   

    这次打印出来的是0了,但是提示“列名 'C60107031730' 无效。
    插入
    test”这个又是为何呢?
      

  5.   

        Exec('update 业务实收表 set 财务结清日期=aa.财务结清日期,业务实收表.电子收据保费=业务实收表.电子收据保费+aa.电子收据保费 from ss_temp aa where aa.保单号=业务实收表.保单号 and aa.保单号='''+@count+'''') 
      

  6.   

    begin
            Exec('insert 业务实收表 select * from ss_temp where ss_temp.保单号='''+@count+'''')
            print '插入'
        print 'test'
      

  7.   

    我们现在使用的这个存储过程不是使用游标一条一条记录地插入吗?为什么我的ss_temp表里面两条两着的记录,他们主键一样,导入数据的时候却提示主键重复呢?我们现在的这个存储过程应该是支持在源数据存在重复,以及在源与目标数据存在重复的时候都可以发现并进行更新的吗?这个又是为什么呢?
      

  8.   

    不用游标不可以吗?update tb set a='a' from tb a where exists(select 1 from b wher a.id=b.id)
    insert into tb select * from tb a where not exists(select 1 from b where a.id=b.id)
      

  9.   

    我们现在使用的这个存储过程不是使用游标一条一条记录地插入吗?为什么我的ss_temp表里面两条两着的记录,他们主键一样,导入数据的时候却提示主键重复呢?我们现在的这个存储过程应该是支持在源数据存在重复,以及在源与目标数据存在重复的时候都可以发现并进行更新的吗?这个又是为什么呢?
    ---
    只要主键不重复就不会出错啦
      

  10.   

    是这样的,我现在的临时表ss_temp存在重复数据,所以我希望一条一条地导入目标数据表“业务实收表”,然后,如果目标表存在这条数据,那么就更新目标表,如果不存在,则插入。如果是按照这种思路进行插入数据的话,目标表应该就不会有重复数据了。所以我在目标表设置主键。但是问题是,我现在遇到的问题是,源数据两条重复的数据要插入目标表时,提示违反了主键的约速。但是我们设想的用游标写的存储过程不是一条一条插入吗?如果说目标数据库不存在这条记录,它应该插入。当源数据的重复数据要插入的时候,根据我们的设计,应该是执行更新的过程,为什么还是提示违反主键约束规则呢?
      

  11.   

    update bb 
    set 财务结清日期=aa.财务结清日期,aa.电子收据保费=bb.电子收据保费+aa.电子收据保费 
    from ss_temp aa 
    right join 业务实收表 bb
    where aa.保单号=bb.保单号 
    and exists(select 1 from 业务实收表 where 保单号=aa.保单号
    insert 业务实收表 
    select * 
    from ss_temp a
    where not exists( select 1 from 业务实收表 where 保单号=a.保单号)
      

  12.   

    我用您的语句修改了一下存储过程,在建立的时候提示:
    “服务器: 消息 1032,级别 15,状态 1,过程 ss,行 14
    无法使用列前缀 'aa'。此前缀必须与 UPDATE 子句 'bb' 中的对象匹配。
    服务器: 消息 156,级别 15,状态 1,过程 ss,行 17
    在关键字 'where' 附近有语法错误。”这个是什么原因呢?谢谢!
      

  13.   

    update bb   
    set 财务结清日期=aa.财务结清日期,bb.电子收据保费=bb.电子收据保费+aa.电子收据保费   
    from ss_temp aa   
    right join 业务实收表 bb  
    on aa.保单号=bb.保单号   
    and exists(select 1 from 业务实收表 where 保单号=aa.保单号  )
    sorry
      

  14.   

    update bb   
    set 财务结清日期=aa.财务结清日期,bb.电子收据保费=bb.电子收据保费+aa.电子收据保费   
    from ss_temp aa   
    right join 业务实收表 bb  
    on aa.保单号=bb.保单号   
    where exists(select 1 from 业务实收表 where 保单号=aa.保单号  )
      

  15.   

    语法既然没错,就只有表ss_temp无记录的可能,
    加上
      select * from ss_temp 看看有无记录
      

  16.   

    星辰技术社区:www.netcsharp.cn,我们将帮您以最快的速度找到最佳的解决方案