SQL存储过程,请大家帮我解释一下

windows2000 2007-03-29 04:18:27
create procedure ordersadd
{
(@customerid int, @cartid nvarchar(50), @orderdate datetime, @shipdate datetime, @orderid int output)
as
begin tran addorder
insert into orders
(@customid,@orderdate,@shipdate)
select @orderid=@@identity

insert into orderdetails --这里有点不能理解,1
(orderid,bookid,quantity,unitcost)
select
@orderid,shoppingCart.book,quantity,books.unitcost
from
shoppingcart inner join books on shoppingcart.bookid=books.bookid
where
cartid=@cartid

exec shoppingcartempty @cartid --这里也有点不懂,2
commit tran addorder
}


不能理解1之前能看懂,用事务,先向orders表中加入数据,并获取自动增量的值到变量@orderid中,后面那个insert语句就看不懂了,为什么没有值呢??还有就是那个exec shoppingcartempty @cartid 是什么意思?,先谢谢大家帮我解决了

...全文
147 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
chenzhaozhan 2007-03-29
  • 打赏
  • 举报
回复
1、从shoppingcart表选择相应的字段插入到orderdetails表中
2、执行一个带@cardid的存储过程hoppingcartempty
tinki 2007-03-29
  • 打赏
  • 举报
回复
quantity 属于哪个表???
job_2006 2007-03-29
  • 打赏
  • 举报
回复
学习
copico 2007-03-29
  • 打赏
  • 举报
回复
insert into orderdetails --这里有点不能理解,1
(orderid,bookid,quantity,unitcost)
select
@orderid,shoppingCart.book,quantity,books.unitcost
from
shoppingcart inner join books on shoppingcart.bookid=books.bookid
where
cartid=@cartid

这是把查出来的信息插插入到表orderdetails

exec shoppingcartempty @cartid --这里也有点不懂,2
这是执行了另一个存储过程。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧