.NET数据库编程求索之路--6.使用ADO.NET实现(三层架构篇-使用List传递数据-基于存储过程)(1)

简介: 6.使用ADO.NET实现(三层架构篇-使用List传递数据-基于存储过程)(1)    【 夏春涛 email: xchuntao@163.com  blog: http://www.cnblogs.

6.使用ADO.NET实现(三层架构篇-使用List传递数据-基于存储过程)(1)

 

 【 夏春涛 email: xchuntao@163.com  blog: http://www.cnblogs.com/SummerRain

6.1 解决方案框架

解决方案(.sln)包含以下几个项目:

(1)类库项目HomeShop.DbUtility,数据访问实用工具;【同5】

(2)类库项目HomeShop.Model,实体层;【同5】

(3)类库项目HomeShop.DAL,数据访问层;

(4)类库项目HomeShop.BLL,业务逻辑层;【同5】

(5)WinForm项目HomeShop.WinForm,界面层。【同5】

 

 

6.2 数据访问层HomeShop.DAL

OrderDAO.cs

  1  using System;
  2  using System.Collections.Generic;
  3  using System.Linq;
  4  using System.Text;
  5  // 新添命名空间
  6  using System.Data;
  7  using System.Data.SqlClient;
  8  using HomeShop.DbUtility;
  9  using HomeShop.Model;
 10 
 11  namespace HomeShop.DAL
 12 {
 13      public  class OrderDAO 
 14     {
 15          protected SqlDbHelper dbHelper;
 16 
 17          public OrderDAO()
 18         {
 19              this.dbHelper =  new SqlDbHelper();
 20         }
 21 
 22          #region 添加
 23          public  int Add(Order order)
 24         {
 25              int rowsCountAffected =  0;
 26             SqlTransaction trans = dbHelper.BeginTransaction();
 27              try
 28             {
 29                  // 新增订单基本信息---------------------------------------------                
 30                   // @OrderID作为传出参数,用于获取新增订单的ID
 31                  SqlParameter paramOrderID =  new SqlParameter( " @OrderID ", SqlDbType.Int);
 32                 paramOrderID.Direction = ParameterDirection.Output;
 33                 SqlParameter[] parameters = {
 34                     paramOrderID,
 35                      new SqlParameter( " @OrderTime ", order.OrderTime),
 36                      new SqlParameter( " @OrderStateCode ", order.OrderStateCode),
 37                      new SqlParameter( " @CustomerName ", order.CustomerName),
 38                      new SqlParameter( " @CustomerPhoneNo ", order.CustomerPhoneNo),
 39                      new SqlParameter( " @CustomerAddress ", order.CustomerAddress)};
 40                 rowsCountAffected += dbHelper.ExecuteNonQueryTrans(trans,  " Order_Insert ", CommandType.StoredProcedure, parameters);
 41                 order.OrderID = ( int)paramOrderID.Value;
 42                  // -----------------------------------------------------------
 43                   // 循环添加订购商品信息
 44                   for ( int i =  0; i < order.OrderItemList.Count; i++)
 45                 {
 46                     SqlParameter paramOrderItemID =  new SqlParameter( " @OrderItemID ", SqlDbType.Int);
 47                     paramOrderItemID.Direction = ParameterDirection.Output;
 48                     SqlParameter[] parametersX = {
 49                         paramOrderItemID,
 50                          new SqlParameter( " @OrderID ", order.OrderID),
 51                          new SqlParameter( " @Product ", order.OrderItemList[i].Product),
 52                          new SqlParameter( " @UnitPrice ", order.OrderItemList[i].UnitPrice),
 53                          new SqlParameter( " @Quantity ", order.OrderItemList[i].Quantity)};
 54                     rowsCountAffected += dbHelper.ExecuteNonQueryTrans(trans,  " OrderItem_Insert ", CommandType.StoredProcedure, parametersX);
 55                 }
 56                 trans.Commit(); // 提交数据库事务
 57                  dbHelper.Close();
 58             }
 59              catch
 60             {
 61                 trans.Rollback(); // 回滚数据库事务
 62                  dbHelper.Close();
 63                  throw;
 64             }            
 65 
 66              return rowsCountAffected;
 67         }
 68          #endregion
 69 
 70          #region 修改
 71          public  int Update(Order order)
 72         {
 73              int rowsCountAffected =  0;        
 74 
 75             List<SqlCmdTextAndParams> listCmdTextAndParams =  new List<SqlCmdTextAndParams>();
 76              // 修改订单基本信息
 77              SqlParameter[] parameters = {
 78                          new SqlParameter( " @OrderTime ", order.OrderTime),
 79                          new SqlParameter( " @OrderStateCode ", order.OrderStateCode),
 80                          new SqlParameter( " @CustomerName ", order.CustomerName),
 81                          new SqlParameter( " @CustomerPhoneNo ", order.CustomerPhoneNo),
 82                          new SqlParameter( " @CustomerAddress ", order.CustomerAddress),
 83                          new SqlParameter( " @OrderID ", order.OrderID)};
 84             listCmdTextAndParams.Add( new SqlCmdTextAndParams( " Order_Update ", CommandType.StoredProcedure, parameters));
 85              // -----------------------------------------------------------
 86               // 循环将订购商品信息列表同步更新到数据库中
 87               // 删除
 88              Order originalOrder =  this.GetSingle(order.OrderID);
 89              for ( int i =  0; i < originalOrder.OrderItemList.Count; i++)
 90             {
 91                  bool exists = order.OrderItemList.Exists(
 92                      delegate(OrderItem item) {  return (item.OrderItemID == originalOrder.OrderItemList[i].OrderItemID); });
 93                  if (exists)  continue;
 94 
 95                 SqlParameter[] parametersX = {
 96                                  new SqlParameter( " @OrderItemID ", originalOrder.OrderItemList[i].OrderItemID)};
 97                 listCmdTextAndParams.Add( new SqlCmdTextAndParams( " OrderItem_Delete ", CommandType.StoredProcedure, parametersX));                
 98             }
 99              // 新增/修改
100              OrderItemDAO orderItemDAO =  new OrderItemDAO();
101              for ( int i =  0; i < order.OrderItemList.Count; i++)
102             {
103                  if ( 0 >= order.OrderItemList[i].OrderItemID) // 新增
104                  {
105                     SqlParameter paramOrderItemID =  new SqlParameter( " @OrderItemID ", SqlDbType.Int);
106                     paramOrderItemID.Direction = ParameterDirection.Output;
107                     SqlParameter[] parametersX = {
108                         paramOrderItemID,
109                          new SqlParameter( " @OrderID ", order.OrderID),
110                          new SqlParameter( " @Product ", order.OrderItemList[i].Product),
111                          new SqlParameter( " @UnitPrice ", order.OrderItemList[i].UnitPrice),
112                          new SqlParameter( " @Quantity ", order.OrderItemList[i].Quantity)};
113                     listCmdTextAndParams.Add( new SqlCmdTextAndParams( " OrderItem_Insert ", CommandType.StoredProcedure, parametersX));
114                 }
115                  else // 修改
116                  {
117                     SqlParameter[] parametersX = {
118                          new SqlParameter( " @OrderItemID ", order.OrderItemList[i].OrderItemID),
119                          new SqlParameter( " @OrderID ", order.OrderID),
120                          new SqlParameter( " @Product ", order.OrderItemList[i].Product),
121                          new SqlParameter( " @UnitPrice ", order.OrderItemList[i].UnitPrice),
122                          new SqlParameter( " @Quantity ", order.OrderItemList[i].Quantity)};                                    
123                     listCmdTextAndParams.Add( new SqlCmdTextAndParams( " OrderItem_Update ", CommandType.StoredProcedure, parametersX));
124                 }
125             }
126             rowsCountAffected = dbHelper.ExecuteNonQueryTrans(listCmdTextAndParams);
127              return rowsCountAffected;
128         }
129          #endregion
130 
131          // 删除
132           public  void Delete( int orderID)
133         {
134             SqlParameter parameter =  new SqlParameter( " @OrderID ",orderID);
135             dbHelper.ExecuteNonQuery( " Order_Delete ", CommandType.StoredProcedure, parameter);
136         }
137 
138          // 获取实体对象列表
139           public List<Order> GetList()
140         {
141              string predicate =  "";
142             DataTable table = GetTable(predicate);
143              return TableToList(table);
144         }
145         
146          // 获取实体对象列表
147           public List<Order> GetList( string customerName)
148         {            
149              string predicate =  "  [CustomerName] LIKE '% " + customerName +  " %' ";
150             DataTable table = GetTable(predicate);
151              return TableToList(table);
152         }
153 
154          // 获取单一实体对象
155           public Order GetSingle( int orderID)
156         {
157              string predicate =  "  [OrderID] =  " + orderID.ToString();
158             DataTable table = GetTable(predicate);
159             List<Order> list = TableToList(table);
160              if (list.Count ==  1)
161             {
162                  // return list[0];
163                  Order order = list[ 0];
164                  // ----子表----
165                  OrderItemDAO orderItemDAO =  new OrderItemDAO();
166                 order.OrderItemList = orderItemDAO.GetList(order.OrderID);
167                  return order;
168             }
169              else  if (list.Count ==  0)
170                  return  null;
171              else
172             {
173                 Exception ex =  new Exception( " 满足条件的实体多于1个。 ");
174                  throw ex;
175             }
176         }
177 
178          // 将DataTable转换为List
179           private List<Order> TableToList(DataTable table)
180         {
181             List<Order> list =  new List<Order>();
182              for ( int i =  0; i < table.Rows.Count; i++)
183             {
184                 list.Add(RowToModel(table.Rows[i]));
185             }
186              return list;
187         }
188 
189          // 获取DataTable
190           private DataTable GetTable( string predicate)
191         {
192             SqlParameter parameter =  new SqlParameter( " @predicate ", predicate);
193              return dbHelper.ExecuteQuery( " Order_Select ", CommandType.StoredProcedure, parameter);
194         }
195         
196          // 将DataRow转换为实体对象
197           private Order RowToModel(DataRow row)
198         {
199              // ----父表----
200              Order order =  new Order();
201             order.OrderID = ( int)row[ " OrderID "];
202             order.CustomerName = row[ " CustomerName "].ToString();
203             order.CustomerPhoneNo = row[ " CustomerPhoneNo "].ToString();
204             order.CustomerAddress = row[ " CustomerAddress "].ToString();
205             order.OrderTime = Convert.ToDateTime(row[ " OrderTime "]);
206             order.OrderStateCode = row[ " OrderStateCode "].ToString();
207             order.OrderStateName = row[ " OrderStateName "].ToString();
208              // ----子表----
209               // OrderItemDAO orderItemDAO = new OrderItemDAO();
210               // order.OrderItemList = orderItemDAO.GetList(order.OrderID);
211              
212              return order;
213         }
214 
215     }
216 }

 

OrderItemDAO.cs

 1  using System;
 2  using System.Collections.Generic;
 3  using System.Linq;
 4  using System.Text;
 5  // 新添命名空间
 6  using System.Data;
 7  using System.Data.SqlClient;
 8  using HomeShop.DbUtility;
 9  using HomeShop.Model;
10 
11  namespace HomeShop.DAL
12 {
13      public  class OrderItemDAO
14     {
15          private SqlDbHelper dbHelper;
16 
17          public OrderItemDAO()
18         { 
19              this.dbHelper  =  new SqlDbHelper();
20         }
21 
22          // 获取实体对象列表
23           public List<OrderItem> GetList( int orderID)
24         {
25             DataTable table = GetTable(orderID);
26              return TableToList(table);
27         }
28 
29          // 将DataTable转换为List
30           private List<OrderItem> TableToList(DataTable table)
31         {
32             List<OrderItem> list =  new List<OrderItem>();
33              for ( int i =  0; i < table.Rows.Count; i++)
34             {
35                 list.Add(RowToModel(table.Rows[i]));
36             }
37              return list;
38         }
39 
40          // 获取DataTable
41           private DataTable GetTable( int orderID)
42         {
43             SqlParameter parameter =  new SqlParameter( " @OrderID ", orderID);
44              return dbHelper.ExecuteQuery( " OrderItem_Select ", CommandType.StoredProcedure, parameter);
45         }
46 
47          // 将DataRow转换为实体对象
48           private OrderItem RowToModel(DataRow row)
49         {
50             OrderItem orderItem =  new OrderItem();
51             orderItem.OrderID = ( int)row[ " OrderID "];
52             orderItem.OrderItemID = ( int)row[ " OrderItemID "];
53             orderItem.Product = row[ " Product "].ToString();
54             orderItem.Quantity = ( int)row[ " Quantity "];
55             orderItem.UnitPrice = ( decimal)row[ " UnitPrice "];
56 
57              return orderItem;
58         }
59     }
60 }

 

OrderStateDAO.cs

 1  using System;
 2  using System.Collections.Generic;
 3  using System.Linq;
 4  using System.Text;
 5  // 新添命名空间
 6  using System.Data;
 7  using System.Data.SqlClient;
 8  using HomeShop.DbUtility;
 9  using HomeShop.Model;
10 
11  namespace HomeShop.DAL
12 {
13      public  class OrderStateDAO
14     {
15          private SqlDbHelper dbHelper;
16 
17          public OrderStateDAO()
18         { 
19              this.dbHelper  =  new SqlDbHelper();
20         }
21 
22          // 获取实体对象列表
23           public List<OrderState> GetList()
24         {
25             DataTable table = GetTable();
26              return TableToList(table);
27         }
28 
29          // 将DataTable转换为List
30           private List<OrderState> TableToList(DataTable table)
31         {
32             List<OrderState> list =  new List<OrderState>();
33              for ( int i =  0; i < table.Rows.Count; i++)
34             {
35                 list.Add(RowToModel(table.Rows[i]));
36             }
37              return list;
38         }
39 
40          // 获取DataTable
41           private DataTable GetTable()
42         {
43              return dbHelper.ExecuteQuery( " OrderState_Select ", CommandType.StoredProcedure,  null);
44         }
45 
46          // 将DataRow转换为实体对象
47           private OrderState RowToModel(DataRow row)
48         {
49             OrderState orderState =  new OrderState();
50             orderState.Code = row[ " Code "].ToString();
51             orderState.Name = row[ " Name "].ToString();
52              return orderState;
53         }
54     }
55 }

 

 

数据库文件:/Files/SummerRain/NetDbDevRoad/HomeShopDB.rar

完整源代码:/Files/SummerRain/NetDbDevRoad/6使用ADONET实现三层架构ListSP.rar

 

 

 

目录
相关文章
|
8月前
|
存储 开发框架 前端开发
前端框架EXT.NET Dotnet 3.5开发的实验室信息管理系统(LIMS)成品源码 B/S架构
发展历史:实验室信息管理系统(LIMS),就是指通过计算机网络技术对实验的各种信息进行管理的计算机软、硬件系统。也就是将计算机网络技术与现代的管理思想有机结合,利用数据处理技术、海量数据存储技术、宽带传输网络技术、自动化仪器分析技术,来对实验室的信息管理和质量控制等进行全方位管理的计算机软、硬件系统,以满足实验室管理上的各种目标(计划、控制、执行)。
73 1
|
8月前
|
数据处理
利用Stream流将取到的对象List<对象>形式数据进行分组统计转变成Map<分组条件,数量统计>形式
利用Stream流将取到的对象List<对象>形式数据进行分组统计转变成Map<分组条件,数量统计>形式
80 0
|
2月前
|
敏捷开发 缓存 中间件
.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素
本文深入探讨了.NET技术的高效开发模式,涵盖面向对象编程、良好架构设计及高效代码编写与管理三大关键要素,并通过企业级应用和Web应用开发的实践案例,展示了如何在实际项目中应用这些模式,旨在为开发者提供有益的参考和指导。
39 3
|
3月前
|
存储 消息中间件 前端开发
.NET常见的几种项目架构模式,你知道几种?
.NET常见的几种项目架构模式,你知道几种?
116 0
|
4月前
|
Python
Python量化炒股的获取数据函数— get_billboard_list()
Python量化炒股的获取数据函数— get_billboard_list()
54 0
|
4月前
|
Java API 开发者
代码小妙招:用Java轻松获取List交集数据
在Java中获取两个 `List`的交集可以通过 `retainAll`方法和Java 8引入的流操作来实现。使用 `retainAll`方法更为直接,但会修改原始 `List`的内容。而使用流则提供了不修改原始 `List`、更为灵活的处理方式。开发者可以根据具体的需求和场景,选择最适合的方法来实现。了解和掌握这些方法,能够帮助开发者在实际开发中更高效地处理集合相关的问题。
110 1
|
5月前
|
设计模式 存储 前端开发
揭秘.NET架构设计模式:如何构建坚不可摧的系统?掌握这些,让你的项目无懈可击!
【8月更文挑战第28天】在软件开发中,设计模式是解决常见问题的经典方案,助力构建可维护、可扩展的系统。本文探讨了.NET中三种关键架构设计模式:MVC、依赖注入与仓储模式,并提供了示例代码。MVC通过模型、视图和控制器分离关注点;依赖注入则通过外部管理组件依赖提升复用性和可测性;仓储模式则统一数据访问接口,分离数据逻辑与业务逻辑。掌握这些模式有助于开发者优化系统架构,提升软件质量。
67 5
|
5月前
|
XML 开发框架 .NET
.NET框架:软件开发领域的瑞士军刀,如何让初学者变身代码艺术家——从基础架构到独特优势,一篇不可错过的深度解读。
【8月更文挑战第28天】.NET框架是由微软推出的统一开发平台,支持多种编程语言,简化应用程序的开发与部署。其核心组件包括公共语言运行库(CLR)和类库(FCL)。CLR负责内存管理、线程管理和异常处理等任务,确保代码稳定运行;FCL则提供了丰富的类和接口,涵盖网络、数据访问、安全性等多个领域,提高开发效率。此外,.NET框架还支持跨语言互操作,允许开发者使用C#、VB.NET等语言编写代码并无缝集成。这一框架凭借其强大的功能和广泛的社区支持,已成为软件开发领域的重要工具,适合初学者深入学习以奠定职业生涯基础。
122 1
|
5月前
|
Python
【Pandas】Pandas的DataFrame按行插入list数据或者读取一行并存为csv文件
本文提供了使用Pandas库对DataFrame进行操作的示例代码。
248 0
|
6月前
|
NoSQL Java Redis
Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推
Redis09-----List类型,有序,元素可以重复,插入和删除快,查询速度一般,一般保存一些有顺序的数据,如朋友圈点赞列表,评论列表等,LPUSH user 1 2 3可以一个一个推