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

简介: 5.使用ADO.NET实现(三层架构篇-使用List传递数据)(1)   5.1 解决方案框架 解决方案(.sln)包含以下几个项目: (1)类库项目HomeShop.DbUtility,数据访问实用工具;【同4.2】 (2)类库项目HomeShop.Model,实体层;【同4.3】 (3)类库项目HomeShop.DAL,数据访问层; (4)类库项目HomeShop.BLL,业务逻辑层; (5)WinForm项目HomeShop.WinForm,界面层。

 

5.使用ADO.NET实现(三层架构篇-使用List传递数据)(1)

 

5.1 解决方案框架

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

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

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

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

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

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

 

5.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          public OrderDAO( string connectionString)
 23         {
 24              this.dbHelper =  new SqlDbHelper(connectionString);
 25         }
 26 
 27          // 添加
 28           public  int Add(Order order)
 29         {
 30              int rowsCountAffected =  0;
 31             SqlTransaction trans = dbHelper.BeginTransaction();
 32              try
 33             {
 34                  // 新增订单基本信息,并使用SQL的系统函数@@IDENTITY获取新增订单的ID
 35                   string sql =  @" INSERT INTO [Order]([OrderTime],
 36                                                     [OrderStateCode],
 37                                                     [CustomerName],
 38                                                     [CustomerPhoneNo],
 39                                                     [CustomerAddress])
 40                                 VALUES(@OrderTime,
 41                                        @OrderStateCode,
 42                                        @CustomerName,
 43                                        @CustomerPhoneNo,
 44                                        @CustomerAddress)
 45                                 SET @OrderID = @@IDENTITY  ";
 46                  // @OrderID作为传出参数,用于获取新增订单的ID
 47                  SqlParameter paramOrderID =  new SqlParameter( " @OrderID ", SqlDbType.Int);
 48                 paramOrderID.Direction = ParameterDirection.Output;
 49                 SqlParameter[] parameters = {
 50                      new SqlParameter( " @OrderTime ", order.OrderTime),
 51                      new SqlParameter( " @OrderStateCode ", order.OrderStateCode),
 52                      new SqlParameter( " @CustomerName ", order.CustomerName),
 53                      new SqlParameter( " @CustomerPhoneNo ", order.CustomerPhoneNo),
 54                      new SqlParameter( " @CustomerAddress ", order.CustomerAddress),
 55                     paramOrderID};
 56                 rowsCountAffected += dbHelper.ExecuteNonQueryTrans(trans, sql, parameters);
 57                 order.OrderID = ( int)paramOrderID.Value;
 58                  // -----------------------------------------------------------
 59                   // 循环添加订购商品信息
 60                   for ( int i =  0; i < order.OrderItems.Count; i++)
 61                 {
 62                      string sqlX =  @" INSERT INTO [OrderItem]([OrderID],
 63                                                  [Product],
 64                                                  [UnitPrice],
 65                                                  [Quantity])
 66                                      VALUES( @OrderID,
 67                                              @Product,
 68                                              @UnitPrice,
 69                                              @Quantity) ";
 70                     SqlParameter[] parametersX = {
 71                          new SqlParameter( " @OrderID ", order.OrderID),
 72                          new SqlParameter( " @Product ", order.OrderItems[i].Product),
 73                          new SqlParameter( " @UnitPrice ", order.OrderItems[i].UnitPrice),
 74                          new SqlParameter( " @Quantity ", order.OrderItems[i].Quantity)};
 75                     rowsCountAffected += dbHelper.ExecuteNonQueryTrans(trans, sqlX, parametersX);
 76                 }
 77                 trans.Commit(); // 提交数据库事务
 78              }
 79              catch
 80             {
 81                 trans.Rollback(); // 回滚数据库事务
 82                   throw;
 83             }
 84             dbHelper.Close();
 85 
 86              return rowsCountAffected;
 87         }
 88 
 89          // 修改
 90           public  int Update(Order order)
 91         {
 92              int rowsCountAffected =  0;            
 93 
 94             List<SqlCmdTextAndParams> listCmdTextAndParams =  new List<SqlCmdTextAndParams>();
 95              // 修改订单基本信息
 96               string sql =  @"  UPDATE [Order]
 97                              SET [OrderTime] = @OrderTime,
 98                                  [OrderStateCode] = @OrderStateCode,
 99                                  [CustomerName] = @CustomerName,
100                                  [CustomerPhoneNo] = @CustomerPhoneNo,
101                                  [CustomerAddress] = @CustomerAddress
102                              WHERE [OrderID] = @OrderID ";
103             SqlParameter[] parameters = {
104                          new SqlParameter( " @OrderTime ", order.OrderTime),
105                          new SqlParameter( " @OrderStateCode ", order.OrderStateCode),
106                          new SqlParameter( " @CustomerName ", order.CustomerName),
107                          new SqlParameter( " @CustomerPhoneNo ", order.CustomerPhoneNo),
108                          new SqlParameter( " @CustomerAddress ", order.CustomerAddress),
109                          new SqlParameter( " @OrderID ", order.OrderID)};
110             listCmdTextAndParams.Add( new SqlCmdTextAndParams(sql, parameters));
111              // -----------------------------------------------------------
112               // 循环将订购商品信息列表同步更新到数据库中
113               // 删除
114               string predicate =  "  OrderID = @OrderID  ";
115             SqlParameter param =  new SqlParameter( " @OrderID ",order.OrderID);
116             Order originalOrder =  this.GetSingle(predicate, param);
117              for( int i= 0;i<originalOrder.OrderItems.Count;i++)
118             {
119                  bool exists = order.OrderItems.Exists(
120                      delegate(OrderItem item){  return (item.OrderItemID == originalOrder.OrderItems[i].OrderItemID);});
121                  if (exists)  continue;
122                 
123                  string sqlX =  @" DELETE FROM [OrderItem]
124                                  WHERE [OrderItemID] = @OrderItemID ";
125                 SqlParameter[] parametersX = {
126                                  new SqlParameter( " @OrderItemID ", originalOrder.OrderItems[i].OrderItemID)};
127                 listCmdTextAndParams.Add( new SqlCmdTextAndParams(sqlX, parametersX));                
128             }
129              // 新增/修改
130              OrderItemDAO orderItemDAO =  new OrderItemDAO();
131              for ( int i =  0; i < order.OrderItems.Count; i++)
132             {
133                  if ( 0 >= order.OrderItems[i].OrderItemID ) // 新增
134                  {
135                      string sqlX =  @" INSERT INTO [OrderItem]([OrderID],
136                                                              [Product],
137                                                              [UnitPrice],
138                                                              [Quantity])
139                                      VALUES( @OrderID,
140                                              @Product,
141                                              @UnitPrice,
142                                              @Quantity) ";
143                     SqlParameter[] parametersX = {
144                                      new SqlParameter( " @OrderID ", order.OrderID),
145                                      new SqlParameter( " @Product ", order.OrderItems[i].Product),
146                                      new SqlParameter( " @UnitPrice ", order.OrderItems[i].UnitPrice),
147                                      new SqlParameter( " @Quantity ", order.OrderItems[i].Quantity)};
148                     listCmdTextAndParams.Add( new SqlCmdTextAndParams(sqlX, parametersX));
149                 }
150                  else // 修改
151                  {
152                      string sqlX =  @" UPDATE [OrderItem]
153                                                  SET [OrderID] = @OrderID,
154                                                      [Product] = @Product,
155                                                      [UnitPrice] = @UnitPrice,
156                                                      [Quantity] = @Quantity
157                                                  WHERE [OrderItemID] = @OrderItemID ";
158                     SqlParameter[] parametersX = {
159                                      new SqlParameter( " @OrderID ", order.OrderID),
160                                      new SqlParameter( " @Product ", order.OrderItems[i].Product),
161                                      new SqlParameter( " @UnitPrice ", order.OrderItems[i].UnitPrice),
162                                      new SqlParameter( " @Quantity ", order.OrderItems[i].Quantity),
163                                      new SqlParameter( " @OrderItemID ", order.OrderItems[i].OrderItemID)};
164                     listCmdTextAndParams.Add( new SqlCmdTextAndParams(sqlX, parametersX));
165                 }
166             }
167             rowsCountAffected = dbHelper.ExecuteNonQueryTrans(listCmdTextAndParams);
168              return rowsCountAffected;
169         }
170         
171          // 删除
172           public  int Delete(Order order)
173         {
174              string sql =  @" DELETE FROM [OrderItem]
175                             WHERE [OrderID] = @OrderID
176                             
177                             DELETE FROM [Order]
178                             WHERE [OrderID] = @OrderID  ";
179              return dbHelper.ExecuteNonQueryTrans(sql,  new SqlParameter( " @OrderID ", order.OrderID));
180         }
181         
182          // 获取实体对象列表
183           public List<Order> GetList( string predicate,  params SqlParameter[] parameters)
184         {
185             List<Order> list =  new List<Order>();
186             DataTable table = GetTable(predicate, parameters);
187              for ( int i =  0; i < table.Rows.Count; i++)
188             {
189                 list.Add(RowToModel(table.Rows[i]));
190             }
191              return list;
192         }
193 
194          // 获取单一实体对象
195           public Order GetSingle( string predicate,  params SqlParameter[] parameters)
196         {
197             List<Order> list = GetList(predicate, parameters);
198              if (list.Count ==  1)
199                  return list[ 0];
200              else  if (list.Count ==  0)
201                  return  null;
202              else
203             {
204                 Exception ex =  new Exception( " 满足条件的实体多于1个。 ");
205                  throw ex;
206             }
207         }
208 
209          // 获取DataTable
210           private DataTable GetTable( string predicate,  params SqlParameter[] parameters)
211         {
212              string sql =  @" SELECT [OrderID],
213                                    [CustomerName],
214                                    [CustomerPhoneNo],
215                                    [CustomerAddress],
216                                    [OrderTime],
217                                    [OrderStateCode],
218                                    [OrderState].[Name] AS [OrderState]
219                              FROM [Order]
220                              LEFT OUTER JOIN [OrderState]
221                              ON [Order].[OrderStateCode] = [OrderState].[Code] ";
222              if ( null != predicate &&  "" != predicate.Trim())
223             {
224                 sql +=  "   WHERE   " + predicate;
225             }
226             sql +=  "  ORDER BY [OrderID] DESC  ";
227              return dbHelper.ExecuteQuery(sql, parameters);
228         }
229         
230          // 将DataRow转换为实体对象
231           private Order RowToModel(DataRow row)
232         {
233              // ----父表----
234              Order order =  new Order();
235             order.OrderID = ( int)row[ " OrderID "];
236             order.CustomerName = row[ " CustomerName "].ToString();
237             order.CustomerPhoneNo = row[ " CustomerPhoneNo "].ToString();
238             order.CustomerAddress = row[ " CustomerAddress "].ToString();
239             order.OrderTime = Convert.ToDateTime(row[ " OrderTime "]);
240             order.OrderStateCode = row[ " OrderStateCode "].ToString();
241              // ----子表----
242              OrderItemDAO orderItemDAO =  new OrderItemDAO();
243             order.OrderItems = orderItemDAO.GetList( " OrderID = @OrderID ",
244                                                      new SqlParameter( " @OrderID ", order.OrderID));
245             
246              return order;
247         }
248 
249     }
250 }

 

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          public OrderItemDAO( string connectionString)
23         {
24              this.dbHelper =  new SqlDbHelper(connectionString);
25         }
26 
27          // 获取实体对象列表
28           public List<OrderItem> GetList( string predicate,  params SqlParameter[] parameters)
29         {
30             List<OrderItem> list =  new List<OrderItem>();
31             DataTable dataTable = GetTable(predicate, parameters);
32              for ( int i =  0; i < dataTable.Rows.Count; i++)
33             {
34                 list.Add(RowToModel(dataTable.Rows[i]));
35             }
36 
37              return list;
38         }
39 
40          // 获取DataTable
41           private DataTable GetTable( string predicate,  params SqlParameter[] parameters)
42         {
43              string sql =  @" SELECT [OrderItemID],
44                                    [OrderID],
45                                    [Product],
46                                    [UnitPrice],
47                                    [Quantity],
48                                    [UnitPrice]*[Quantity] AS SubTotal
49                             FROM [OrderItem] ";
50              if ( null != predicate &&  "" != predicate.Trim())
51             {
52                 sql +=  "   WHERE   " + predicate;
53             }
54              return dbHelper.ExecuteQuery(sql, parameters);
55         }
56 
57          // 将DataRow转换为实体对象
58           private OrderItem RowToModel(DataRow row)
59         {
60             OrderItem orderItem =  new OrderItem();
61             orderItem.OrderID = ( int)row[ " OrderID "];
62             orderItem.OrderItemID = ( int)row[ " OrderItemID "];
63             orderItem.Product = row[ " Product "].ToString();
64             orderItem.Quantity = ( int)row[ " Quantity "];
65             orderItem.UnitPrice = ( decimal)row[ " UnitPrice "];
66 
67              return orderItem;
68         }
69     }
70 }

 

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          public OrderStateDAO( string connectionString)
23         {
24              this.dbHelper =  new SqlDbHelper(connectionString);
25         }
26 
27          // 获取实体对象列表
28           public List<OrderState> GetList( string predicate,  params SqlParameter[] parameters)
29         {
30             List<OrderState> list =  new List<OrderState>();
31             DataTable dataTable = GetTable(predicate, parameters);
32              for ( int i =  0; i < dataTable.Rows.Count; i++)
33             {
34                 list.Add(RowToModel(dataTable.Rows[i]));
35             }
36 
37              return list;
38         }
39 
40          // 获取DataTable
41           private DataTable GetTable( string predicate,  params SqlParameter[] parameters)
42         {
43              string sql =  @" SELECT * FROM [OrderState] ";
44              if ( null != predicate &&  "" != predicate.Trim())
45             {
46                 sql +=  "   WHERE   " + predicate;
47             }
48             sql +=  "  ORDER BY [Code]  ";
49              return dbHelper.ExecuteQuery(sql, parameters);
50         }
51 
52          // 将DataRow转换为实体对象
53           private OrderState RowToModel(DataRow row)
54         {
55             OrderState orderState =  new OrderState();
56             orderState.Code = row[ " Code "].ToString();
57             orderState.Name = row[ " Name "].ToString();
58              return orderState;
59         }
60     }
61 }

 

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

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

 

目录
相关文章
|
6天前
|
消息中间件 存储 缓存
十万订单每秒热点数据架构优化实践深度解析
【11月更文挑战第20天】随着互联网技术的飞速发展,电子商务平台在高峰时段需要处理海量订单,这对系统的性能、稳定性和扩展性提出了极高的要求。尤其是在“双十一”、“618”等大型促销活动中,每秒需要处理数万甚至数十万笔订单,这对系统的热点数据处理能力构成了严峻挑战。本文将深入探讨如何优化架构以应对每秒十万订单级别的热点数据处理,从历史背景、功能点、业务场景、底层原理以及使用Java模拟示例等多个维度进行剖析。
27 8
|
8天前
|
存储 分布式计算 数据挖掘
数据架构 ODPS 是什么?
数据架构 ODPS 是什么?
67 7
|
8天前
|
数据采集 搜索推荐 数据管理
数据架构 CDP 是什么?
数据架构 CDP 是什么?
31 2
|
1月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
172 3
|
2月前
|
NoSQL 关系型数据库 MySQL
微服务架构下的数据库选择:MySQL、PostgreSQL 还是 NoSQL?
在微服务架构中,数据库的选择至关重要。不同类型的数据库适用于不同的需求和场景。在本文章中,我们将深入探讨传统的关系型数据库(如 MySQL 和 PostgreSQL)与现代 NoSQL 数据库的优劣势,并分析在微服务架构下的最佳实践。
|
2月前
|
消息中间件 缓存 监控
优化微服务架构中的数据库访问:策略与最佳实践
在微服务架构中,数据库访问的效率直接影响到系统的性能和可扩展性。本文探讨了优化微服务架构中数据库访问的策略与最佳实践,包括数据分片、缓存策略、异步处理和服务间通信优化。通过具体的技术方案和实例分析,提供了一系列实用的建议,以帮助开发团队提升微服务系统的响应速度和稳定性。
|
18天前
|
存储 SQL Apache
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
Apache Doris 是一个基于 MPP 架构的高性能实时分析数据库,以其极高的速度和易用性著称。它支持高并发点查询和复杂分析场景,适用于报表分析、即席查询、数据仓库和数据湖查询加速等。最新发布的 2.0.2 版本在性能、稳定性和多租户支持方面有显著提升。社区活跃,已广泛应用于电商、广告、用户行为分析等领域。
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
|
18天前
|
缓存 关系型数据库 MySQL
高并发架构系列:数据库主从同步的 3 种方案
本文详解高并发场景下数据库主从同步的三种解决方案:数据主从同步、数据库半同步复制、数据库中间件同步和缓存记录写key同步,旨在帮助解决数据一致性问题。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
高并发架构系列:数据库主从同步的 3 种方案
|
8天前
|
存储 缓存 NoSQL
2款使用.NET开发的数据库系统
2款使用.NET开发的数据库系统
|
1月前
|
存储 搜索推荐 C++
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器2
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器
51 2
【C++篇】深度剖析C++ STL:玩转 list 容器,解锁高效编程的秘密武器2
下一篇
无影云桌面