澳门贵宾会注册送豪礼ABAP SY-SUBRC 使用过程中返回值的几种含义

实现

 

1)有相同的数据,直接返回;

当进行Debug的时候,经常会遇到”SY-SUBRC”的返回值。具体如何使用。在各种语句下返回值。

2)有主键相同,但是数据不同的数据,进行更新处理;

================= FUNCTION MODULE (或RFC中) SY-SUBRC 的含义

使用SELECT语句选择查询:
SY-SUBRC = 0:
至少有一行数据,当ENDSELECT语句执行完,SY-DBCNT中保存着记录的个数。
SY-SUBRC = 4: 没有数据。
SY-SUBRC = 8: 只有使用“SELECT SINGLE FOR UPDATE”时才会有,
澳门贵宾会注册送豪礼,              表示: WHERE条件指定的记录不止一行,结果是没有记录被选中。

使用INSERT语句,向表中插入一行,必须注意INSERT的顺序与表中字段的顺序一致:
SY-SUBRC = 0: 插入成功,SY-DBCNT包含了插入的行数,0或1。
SY-SUBRC = 4: 由于有相同的KEY存在,所以插入失败。

使用LOOP语句来遍历一个内表:
SY-SUBRC = 0: 循环至少被执行一次。
SY-SUBRC = 4:
循环没有被执行,可能是没有数据,也可能是没有符合条件的记录。

使用DELETE语句来删除一条记录:
SY-SUBRC = 0:
找到一行并删除之,如果该表有不唯一主键,也就是有多条重复的记录,则只删除第一条记录。
SY-SUBRC = 4: 没有找到符合条件的记录,也没有删除。

使用UPDATE语句来更新一条记录:
SY-SUBRC = 0: 找到记录并更新,(如果有多条记录呢?)
SY-SUBRC = 4: 没有找到符合条件的记录,也没有更新。

3)没有数据,进行插入数据处理。

Create proc Insert_Update @Id varchar(20), @Name varchar(20), @Telephone varchar(20), @Address varchar(20), @Job varchar(20), @returnValue int output as declare @tmpName varchar(20), @tmpTelephone varchar(20),@tmpJob varchar(20),@tmpAddress varchar(20)if exists(select * from dbo.DemoData where id=@Id) begin select @tmpName=Name,@tmpTelephone=Telephone,@tmpAddress=Address,@tmpJob=Job from dbo.DemoData where id=@Id if ((@tmpName=@Name) and (@tmpTelephone=@Telephone) and (@tmpAddress=@Address)and (@tmpJob=@Job)) begin set @returnValue=0 --有相同的数据,直接返回值 end else begin update dbo.DemoData set Name=@Name,Telephone=@Telephone,Address=@Address,Job=@Job where id=@Id set @returnValue=2 --有主键相同的数据,进行更新处理 end end else begin insert into dbo.DemoData values(@Id,@Name,@Telephone,@Address,@Job) set @returnValue=1 --没有相同的数据,进行插入处理 end

declare @returnValue int exec Insert_Update '15','hugh15','3823345','长安街','副部长',@returnValue output select @returnValue

返回值0,已经存在相同的

返回值1,插入成功

返回值2,更新成功

发表评论

电子邮件地址不会被公开。 必填项已用*标注