• 全部
  • C#综合技术
  • C#互联网桌面应用
  • AppLauncher
  • WinForm&WPF
  • C#开发新技术
  • 问答

大家看看这个存储过程有什么问题了!

tshulinzi 2004-11-03 11:17:50
CREATE PROCEDURE insertstore
(
@number nvarchar(10),
@amount int
)
AS
select number,amount as num from table_store where number=@number

if(@@Rowcount>0)

insert into table_store
values
(
@number,
amount=(num+@amount)
)

else

insert into table_store
values
(
@number,
@amount
)
return
GO
...全文
53 点赞 收藏 6
写回复
6 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
reddg 2004-11-03
declare @num int
set @num=0
select @num=amount from table_store where number=@number
insert into table_store
values
(
@number,
@num+@amount
)
回复
白云在上 2004-11-03
不懂楼主什么目的。但以下这句,如果 number是主键的话,将出错。
if(@@Rowcount>0)
insert into table_store
values
(
@number,
amount=(num+@amount)
)

猜想楼主是要实现以下目的吧:
if(@@Rowcount>0)
update table_store set amount=amount + @amount where number=@number
回复
tshulinzi 2004-11-03
上面的不行!
回复
gaoxiaospring 2004-11-03
修改一下:
CREATE PROCEDURE insertstore
(
@number nvarchar(10),
@amount int
)
AS

declare num int

select num=amount from table_store where number=@number

if(@@Rowcount>0)

insert into table_store
values
(
@number,
amount=(num+@amount)
)

else

insert into table_store
values
(
@number,
@amount
)
return
GO
回复
shuker 2004-11-03
insert into table_store
values
(
@number,
amount=(num+@amount)//这里不对
)
回复
gaoxiaospring 2004-11-03
/*****************
insert into table_store
values
(
@number,
amount=(num+@amount)
)
*****************/

num的值是多少?在上面一句select中并没有保存这个值。
回复
相关推荐
发帖
C#
创建于2007-09-28

10.5w+

社区成员

.NET技术 C#
申请成为版主
帖子事件
创建了帖子
2004-11-03 11:17
社区公告

让您成为最强悍的C#开发者