.net基础---数据库操作

 ADO.NET

ADO.NET是.NET数据库的访问架构,ADO是ActiveX Data Objects的缩写。ADO.NET是数据库应用程序和数据源之间沟通的桥梁,主要提供一个面向对象的数据访问架构,用于快速实现对数据库进行操作(curd)
ADO.NET中的五个主要对象

  • 1、DbConnection:数据库连接对象,主要用于实现程序与数据库之间建立连接。需要注意的是:在开发过程中尽量避免过于频繁的创建/释放connection,因为过多的数据库连接可能会导致数据性能瓶颈。
  • 2、DbCommand:数据库指令对象,主要是对数据库发送相关指令操作数据库中数据。
  • 3、DbDataAdapter:数据适配器,主要是可以实现数据源和dataset/datatable之间的数据传输适配。它可以实现将数据库数据适配到dataset中(通过Fill方法),也可以实现将dataset中的数据变更更新到数据库中(通过Update方法)。
  • 4、DataSet:数据集,数据暂存区,它是支持ADO.NET断开式、分布式数据方案的核心对象,是实现基于非连接的数据查询的核心组件。DataSet可以视为是数据库中的指定数据被复制内存中而创建的小型数据库。DataSet本身只是一个数据暂存区,它没有能力直接与数据库沟通的,它与数据库之间一般是由DbDataAdapter来实现的。
  • 5、DbDataReader:它提供了顺序的,只读的方式读取Command对象获得的数据结果集,DataReader会以独占的方式打开数据库连接。DataReader只执行读操作,并且每次只在内存缓冲区里存储结果集的一条数据,所以使用Datareader对象的效率比较高,如果要查询大量数据,同时不需要修改数据时,DataReader是非常好的选择。

DbHelper

  1    public class MysqlDbHelper
  2     {
  3         public static string connectionString = "Server=localhost;Port=3306;Database=myDataBase;Uid=john_yong;Pwd=root3295;";
  4         public static MySqlConnection GetConnection()
  5         {
  6             return new MySqlConnection(connectionString);
  7         }
  8       
  9         #region sync
 10 
 11         public static int ExecuteNonQuery(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 12         {
 13             using (var connection =GetConnection())
 14             using (var command = new MySqlCommand())
 15             {
 16                 PrepareCommand(command, connection,cmdText, commandType, null,parameters);
 17                 return command.ExecuteNonQuery();
 18             }
 19         }
 20 
 21         public static object ExecuteScalar(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 22         {
 23             using (var connection = GetConnection())
 24             using (var command = new MySqlCommand())
 25             {
 26                 PrepareCommand(command,connection, cmdText, commandType, null, parameters);
 27                 return command.ExecuteScalar();
 28             }
 29 
 30         }
 31 
 32         public static DataTable ExecuteDataTable(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 33         {
 34             DataTable datatable = new DataTable();
 35             using (var connection = GetConnection())
 36             using (var command = new MySqlCommand())
 37             {
 38                 PrepareCommand(command,connection, cmdText, commandType, null, parameters);
 39                 MySqlDataAdapter adapter = new MySqlDataAdapter(command);
 40                 adapter.Fill(datatable);
 41                 return datatable;
 42 
 43             }
 44         }
 45 
 46         public static DataSet ExecuteDataSet(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 47         {
 48             DataSet dataset = new DataSet();
 49             using (var connection = GetConnection())
 50             using (var command = new MySqlCommand())
 51             {
 52                 PrepareCommand(command, connection,cmdText, commandType, null, parameters);
 53                 MySqlDataAdapter adapter = new MySqlDataAdapter(command);
 54                 adapter.Fill(dataset);
 55                 return dataset;
 56             }
 57         }
 58 
 59         public static MySqlDataReader ExecuteReader(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 60         {
 61             using (var connection = GetConnection())
 62             using (var command = new MySqlCommand())
 63             {
 64                 PrepareCommand(command,connection, cmdText, commandType, null, parameters);
 65                 return command.ExecuteReader();
 66             }
 67         }
 68 
 69         #endregion
 70 
 71         #region async 
 72 
 73         public static async Task<int> ExecuteNonQueryAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null, MySqlTransaction mySqlTransaction = null)
 74         {
 75             using (var connection = GetConnection())
 76             using (var command = new MySqlCommand())
 77             {
 78                 PrepareCommand(command,connection, cmdText, commandType, mySqlTransaction, parameters);
 79                 return await command.ExecuteNonQueryAsync();
 80             }
 81         } 
 82 
 83         public static async Task<object> ExecuteScalarAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 84         {
 85             using (var connection = GetConnection())
 86             using (var command = new MySqlCommand())
 87             {
 88                 PrepareCommand(command,connection, cmdText, commandType, null, parameters);
 89                 return await command.ExecuteScalarAsync();
 90             }
 91 
 92         } 
 93 
 94         public static async Task<DataTable> ExecuteDataTableAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 95         {
 96             DataTable datatable = new DataTable();
 97             using (var connection = GetConnection())
 98             using (var command = new MySqlCommand())
 99             {
100                 PrepareCommand(command, connection, cmdText, commandType, null, parameters);
101                 MySqlDataAdapter adapter = new MySqlDataAdapter(command);
102                 await adapter.FillAsync(datatable);
103                 return datatable;
104             }
105         } 
106 
107         public static async Task<DataSet> ExecuteDataSetAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
108         {
109             DataSet dataset = new DataSet();
110             using (var connection = GetConnection())
111             using (var command = new MySqlCommand())
112             {
113                 PrepareCommand(command, connection, cmdText, commandType, null, parameters);
114                 MySqlDataAdapter adapter = new MySqlDataAdapter(command);
115                 await adapter.FillAsync(dataset);
116                 return dataset;
117             }
118         }
119         /// <summary>
120         /// reader
121         /// </summary>
122         /// <param name="cmdText"></param>
123         /// <param name="commandType"></param>
124         /// <param name="parameters"></param>
125         /// <returns></returns>
126         public static async Task<DbDataReader> ExecuteReaderAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
127         {
128             using (var connection = GetConnection())
129             using (var command = new MySqlCommand())
130             {
131                 PrepareCommand(command,connection, cmdText, commandType, null, parameters);
132                 return await command.ExecuteReaderAsync();
133             }
134         }
135 
136         #endregion
137 
138         #region private Method
139 
140         private static void PrepareCommand(MySqlCommand command,MySqlConnection connection, string commandText, CommandType commandType, MySqlTransaction transaction, Dictionary<string, object> parameters)
141         {
142             command.CommandText = commandText;
143             command.CommandType = commandType;
144             if (connection.State != ConnectionState.Open)
145             {
146                 connection.Open();
147             }
148             command.Connection = connection;
149             if (transaction != null)
150             {
151                 command.Transaction = transaction;
152             }
153             AttachParameter(command, parameters);
154         }
155 
156         private static void AttachParameter(MySqlCommand command, Dictionary<string, object> parameters)
157         {
158             if (parameters != null && parameters.Count > 0)
159             {
160                 foreach (var parameterItem in parameters)
161                 {
162                     command.Parameters.Add(new MySqlParameter(parameterItem.Key, parameterItem.Value));
163                 }
164             }
165         }
166 
167         #endregion
168     }

 

以上是简单的数据操作帮助类,对于非常简单的增删改查还是可以应付的(但是对于事务的支持是不够的)。

简单封装Db操作--支持事务

一、 创建Db操作类(不再使用静态的dbHelper)

  1     public class MysqlOperator
  2     {
  3         private readonly MySqlConnection _mySqlConnection;
  4         public MysqlOperator(MySqlConnection mySqlConnection)
  5         {
  6             this._mySqlConnection = mySqlConnection;
  7         }
  8         #region sync
  9         public int ExecuteNonQuery(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null,MySqlTransaction mySqlTransaction=null)
 10         {
 11             using (var command = new MySqlCommand())
 12             {
 13                 PrepareCommand(command, cmdText, commandType, mySqlTransaction, parameters);
 14                 return command.ExecuteNonQuery();
 15             }
 16         }
 17 
 18         public object ExecuteScalar(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 19         {
 20             using (var command = new MySqlCommand())
 21             {
 22                 PrepareCommand(command, cmdText, commandType, null, parameters);
 23                 return command.ExecuteScalar();
 24             }
 25 
 26         }
 27 
 28         public DataTable ExecuteDataTable(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 29         {
 30             DataTable datatable = new DataTable();
 31 
 32             using (var command = new MySqlCommand())
 33             {
 34                 PrepareCommand(command, cmdText, commandType, null, parameters);
 35                 MySqlDataAdapter adapter = new MySqlDataAdapter(command);
 36                 adapter.Fill(datatable);
 37                 return datatable;
 38 
 39             }
 40         }
 41         public DataSet ExecuteDataSet(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 42         {
 43             DataSet dataset = new DataSet();
 44 
 45             using (var command = new MySqlCommand())
 46             {
 47                 PrepareCommand(command, cmdText, commandType, null, parameters);
 48                 MySqlDataAdapter adapter = new MySqlDataAdapter(command); 
 49                 adapter.Fill(dataset);
 50                 return dataset; 
 51             }
 52         }
 53         public MySqlDataReader ExecuteReader(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 54         {
 55             using (var command = new MySqlCommand())
 56             {
 57                 PrepareCommand(command, cmdText, commandType, null, parameters);
 58                 return command.ExecuteReader();
 59             }
 60         }
 61         #endregion
 62         #region async 
 63         public async Task<int> ExecuteNonQueryAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null, MySqlTransaction mySqlTransaction = null)
 64         {
 65             using (var command = new MySqlCommand())
 66             {
 67                 PrepareCommand(command, cmdText, commandType, mySqlTransaction, parameters);
 68                 return await command.ExecuteNonQueryAsync();
 69             }
 70         }
 71 
 72         public async Task<object> ExecuteScalarAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 73         {
 74             using (var command = new MySqlCommand())
 75             {
 76                 PrepareCommand(command, cmdText, commandType, null, parameters);
 77                 return await command.ExecuteScalarAsync();
 78             }
 79 
 80         }
 81 
 82         //public async  Task<DataTable> ExecuteDataTableAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 83         //{
 84         //    DataTable datatable = new DataTable();
 85 
 86         //    using (var command = new MySqlCommand())
 87         //    {
 88         //        PrepareCommand(command, cmdText, commandType, null, parameters);
 89         //        MySqlDataAdapter adapter = new MySqlDataAdapter(command);
 90         //        await adapter.FillAsync(datatable);
 91         //        return datatable; 
 92         //    }
 93         //}
 94         //public async Task<DataSet> ExecuteDataSetAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
 95         //{
 96         //    DataSet dataset = new DataSet();
 97 
 98         //    using (var command = new MySqlCommand())
 99         //    {
100         //        PrepareCommand(command, cmdText, commandType, null, parameters);
101         //        MySqlDataAdapter adapter = new MySqlDataAdapter(command);
102         //        await  adapter.FillAsync(dataset);
103         //        return dataset;
104         //    }
105         //}
106 
107 
108         /// <summary>
109         /// 
110         /// </summary>
111         /// <param name="cmdText"></param>
112         /// <param name="commandType"></param>
113         /// <param name="parameters"></param>
114         /// <returns></returns>
115         public async Task<DbDataReader> ExecuteReaderAsync(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
116         {
117             using (var command = new MySqlCommand())
118             {
119                 PrepareCommand(command, cmdText, commandType, null, parameters);
120                 return await command.ExecuteReaderAsync();
121             }
122         }
123         #endregion
124         #region private Method
125         private void PrepareCommand(MySqlCommand command, string commandText, CommandType commandType, MySqlTransaction transaction, Dictionary<string, object> parameters)
126         {
127             command.CommandText = commandText;
128             command.CommandType = commandType;
129             if (_mySqlConnection.State != ConnectionState.Open)
130             {
131                 _mySqlConnection.Open();
132             }
133             command.Connection = _mySqlConnection;
134             if (transaction != null)
135             {
136                 command.Transaction = transaction;
137             }
138             AttachParameter(command, parameters); 
139         }
140         private void AttachParameter(MySqlCommand command, Dictionary<string, object> parameters)
141         {
142             if (parameters != null && parameters.Count > 0)
143             {
144                 foreach (var parameterItem in parameters)
145                 {
146                     command.Parameters.Add(new MySqlParameter(parameterItem.Key, parameterItem.Value));
147                 }
148             }
149         }
150         #endregion
151     }

 

二、定义数据操作管理类

 1     public class SqlManagement : IDisposable
 2     {
 3         private readonly IConfiguration _configuration;
 4         private readonly MysqlOperator _mysqlOperator;
 5         private readonly string _connectionString;
 6         public SqlManagement(IConfiguration configuration)
 7         {
 8             this._configuration = configuration;
 9             this._mySqlConnection = new MySqlConnection(_configuration.GetConnectionString("mysqlconnection"));
10             this._mysqlOperator = new MysqlOperator(_mySqlConnection);
11         }
12         private MySqlConnection _mySqlConnection;
13         private MySqlTransaction _mySqlTransaction;
14         public void BeginTransaction()
15         {
16             _mySqlTransaction = _mySqlConnection.BeginTransaction();
17         }
18         public void Commit()
19         {
20             if (_mySqlTransaction != null)
21             {
22                 _mySqlTransaction.Commit();
23             }
24             if (_mySqlConnection != null)
25             {
26                 _mySqlConnection.Close();
27             }
28         }
29         public void Rollback()
30         {
31             if (_mySqlTransaction != null)
32             {
33                 _mySqlTransaction.Rollback();
34             }
35             if (_mySqlConnection != null)
36             {
37                 _mySqlConnection.Close();
38             }
39         }
40         public void Dispose()
41         {
42             if (_mySqlConnection != null)
43             {
44                 _mySqlConnection.Dispose();
45                 _mySqlConnection = null;
46             }
47         }
48 
49         #region 
50         public int ExecuteNonQuery(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
51         {
52             if (_mySqlTransaction != null)
53             {
54                 return _mysqlOperator.ExecuteNonQuery(cmdText, commandType, parameters, _mySqlTransaction);
55             }
56             else
57             {
58                 return _mysqlOperator.ExecuteNonQuery(cmdText, commandType, parameters);
59             }
60         }
61 
62         public object ExecuteScalar(string cmdText, CommandType commandType = CommandType.Text, Dictionary<string, object> parameters = null)
63         {
64             return _mysqlOperator.ExecuteScalar(cmdText, commandType, parameters);
65         }
66         #endregion
67     }

 

其实已经有很多组件已经实现了很好的数据库操作的封装了,例如Dapper、EF等。此处仅算是对数据库操作的回顾!

 

----------

本文地址:https://www.cnblogs.com/johnyong/p/14152891.html

posted on 2021-04-19 00:03  john_yong  阅读(605)  评论(0编辑  收藏  举报

导航