晒晒我的通用数据访问层

发表于:2011-7-07 10:05

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:李奇峰    来源:51Testing软件测试网采编

  2. 示范代码,以事务方式调用多个存储过程

  C#实体类型,成员与数据库表对应,这里就不给出表结构截图了。

  1. public sealed class OrderItem  
  2. {  
  3.     public int OrderID { getset; }  
  4.     public int? CustomerID { getset; }  
  5.     public DateTime OrderDate { getset; }  
  6.     public decimal SumMoney { getset; }  
  7.     [ItemField(OnlyLoadAll = true)]    // 仅当加载详细信息时才加载它。  
  8.     public string Comment { getset; }  
  9.     public bool Finished { getset; }  
  10.     public string CustomerName { getset; }  
  11.  
  12.     [ItemField(IgnoreLoad=true)]    // 不加载这个成员  
  13.     public List<OrderDetail> Detail;  
  14. }  
  15.  
  16. public sealed class OrderDetail  
  17. {  
  18.     public int OrderID { getset; }  
  19.     public int ProductID { getset; }  
  20.     public decimal UnitPrice { getset; }  
  21.     public int Quantity { getset; }  
  22. }

  三个存储过程,用于插入主表,子表,刷新总金额

  1. create procedure [dbo].[InsertOrder](  
  2.     @CustomerID int = null,  
  3.     @SumMoney money,  
  4.     @Comment nvarchar(300),  
  5.     @OrderID int output  
  6. )  
  7. as 
  8. begin  
  9.    
  10. insert into Orders( CustomerID, OrderDate, SumMoney, Comment)  
  11. values( @CustomerID, getdate(), @SumMoney, @Comment);  
  12.    
  13. set @OrderID = scope_identity();  
  14.    
  15. end;  
  16. create procedure [dbo].[InsertOrderDetail](  
  17.     @OrderID int,  
  18.     @ProductID int,  
  19.     @Quantity int 
  20. )  
  21. as 
  22. declare @Price money;  
  23. select @Price = (select UnitPrice from Products where ProductID = @ProductID);  
  24.  
  25. insert into [Order Details] (OrderID, ProductID, UnitPrice, Quantity)  
  26. values (@OrderID, @ProductID, @Price, @Quantity);  
  27.  
  28.  
  29. create procedure [dbo].[RefreshOrderSumMoney](  
  30.     @OrderID int 
  31. )  
  32. as 
  33. declare @SumMoney money;  
  34. select @SumMoney = (select sum(UnitPrice * Quantity) from [Order Details] where OrderID = @OrderID);  
  35.  
  36. update Orders set SumMoney = @SumMoney  where OrderID = @OrderID;  
  37.  

43/4<1234>
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号