zoukankan      html  css  js  c++  java
  • DbHelper

    1、类代码

    1. using System;  
    2.   
    3. using System.Configuration;  
    4.   
    5. using System.Data;  
    6.   
    7. using System.Data.Common;  
    8.   
    9. using System.Data.OleDb;  
    10.   
    11. using System.Data.SqlClient;  
    12.   
    13. namespace Lelog.Data  
    14.   
    15. {  
    16.   
    17. /// <summary>  
    18.   
    19. /// <a href="http://lib.csdn.net/base/14" class='replace_word' title="MySQL知识库" target='_blank' style='color:#df3434; font-weight:bold;'>数据库</a>助手类  
    20.   
    21. /// </summary>  
    22.   
    23. public class DbHelper  
    24.   
    25. {  
    26.   
    27. private static string dbProviderName = ConfigurationSettings.AppSettings["DbProviderName"];  
    28.   
    29. private static string dbConnectionString = ConfigurationManager.AppSettings["TaxInvoiceConn"];  
    30.   
    31.   
    32. private DbConnection connection;  
    33.   
    34. public DbHelper()  
    35.   
    36. {  
    37.   
    38. this.connection = CreateConnection(DbHelper.dbConnectionString);  
    39.   
    40. }  
    41.   
    42.   
    43. public DbHelper(string connectionString)  
    44.   
    45. {  
    46.   
    47. this.connection = CreateConnection(connectionString);  
    48.   
    49. }  
    50.   
    51.   
    52. public static DbConnection CreateConnection()  
    53.   
    54. {  
    55.   
    56. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    57.   
    58. DbConnection dbconn = dbfactory.CreateConnection();  
    59.   
    60. dbconn.ConnectionString = DbHelper.dbConnectionString;  
    61.   
    62. return dbconn;  
    63.   
    64. }  
    65.   
    66. public static DbConnection CreateConnection(string connectionString)  
    67.   
    68. {  
    69.   
    70. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    71.   
    72. DbConnection dbconn = dbfactory.CreateConnection();  
    73.   
    74. dbconn.ConnectionString = connectionString;  
    75.   
    76. return dbconn;  
    77.   
    78. }  
    79.   
    80.   
    81. public DbCommand GetStoredProcCommond(string storedProcedure)  
    82.   
    83. {  
    84.   
    85. DbCommand dbCommand = connection.CreateCommand();  
    86.   
    87. dbCommand.CommandText = storedProcedure;  
    88.   
    89. dbCommand.CommandType = CommandType.StoredProcedure;  
    90.   
    91. return dbCommand;  
    92.   
    93. }  
    94.   
    95. public DbCommand GetSqlStringCommond(string sqlQuery)  
    96.   
    97. {  
    98.   
    99. DbCommand dbCommand = connection.CreateCommand();  
    100.   
    101. dbCommand.CommandText = sqlQuery;  
    102.   
    103. dbCommand.CommandType = CommandType.Text;  
    104.   
    105. return dbCommand;  
    106.   
    107. }  
    108.  
    109. #region 增加参数  
    110.   
    111. public void AddParameterCollection(DbCommand cmd, DbParameterCollection dbParameterCollection)  
    112.   
    113. {  
    114.   
    115. foreach (DbParameter dbParameter in dbParameterCollection)  
    116.   
    117. {  
    118.   
    119. cmd.Parameters.Add(dbParameter);  
    120.   
    121. }  
    122.   
    123. }  
    124.   
    125. public void AddOutParameter(DbCommand cmd, string parameterName, DbType dbType, int size)  
    126.   
    127. {  
    128.   
    129. DbParameter dbParameter = cmd.CreateParameter();  
    130.   
    131. dbParameter.DbType = dbType;  
    132.   
    133. dbParameter.ParameterName = parameterName;  
    134.   
    135. dbParameter.Size = size;  
    136.   
    137. dbParameter.Direction = ParameterDirection.Output;  
    138.   
    139. cmd.Parameters.Add(dbParameter);  
    140.   
    141. }  
    142.   
    143. public void AddInParameter(DbCommand cmd, string parameterName, DbType dbType, object value)  
    144.   
    145. {  
    146.   
    147. DbParameter dbParameter = cmd.CreateParameter();  
    148.   
    149. dbParameter.DbType = dbType;  
    150.   
    151. dbParameter.ParameterName = parameterName;  
    152.   
    153. dbParameter.Value = value;  
    154.   
    155. dbParameter.Direction = ParameterDirection.Input;  
    156.   
    157. cmd.Parameters.Add(dbParameter);  
    158.   
    159. }  
    160.   
    161. public void AddReturnParameter(DbCommand cmd, string parameterName, DbType dbType)  
    162.   
    163. {  
    164.   
    165. DbParameter dbParameter = cmd.CreateParameter();  
    166.   
    167. dbParameter.DbType = dbType;  
    168.   
    169. dbParameter.ParameterName = parameterName;  
    170.   
    171. dbParameter.Direction = ParameterDirection.ReturnValue;  
    172.   
    173. cmd.Parameters.Add(dbParameter);  
    174.   
    175. }  
    176.   
    177. public DbParameter GetParameter(DbCommand cmd, string parameterName)  
    178.   
    179. {  
    180.   
    181. return cmd.Parameters[parameterName];  
    182.   
    183. }  
    184.  
    185.  
    186. #endregion  
    187.  
    188. #region 执行  
    189.   
    190. public DataSet ExecuteDataSet(DbCommand cmd)  
    191.   
    192. {  
    193.   
    194. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    195.   
    196. DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();  
    197.   
    198. dbDataAdapter.SelectCommand = cmd;  
    199.   
    200. DataSet ds = new DataSet();  
    201.   
    202. dbDataAdapter.Fill(ds);  
    203.   
    204. return ds;  
    205.   
    206. }  
    207.   
    208.   
    209. public DataTable ExecuteDataTable(DbCommand cmd)  
    210.   
    211. {  
    212.   
    213. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    214.   
    215. DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();  
    216.   
    217. dbDataAdapter.SelectCommand = cmd;  
    218.   
    219. DataTable dataTable = new DataTable();  
    220.   
    221. dbDataAdapter.Fill(dataTable);  
    222.   
    223. return dataTable;  
    224.   
    225. }  
    226.   
    227.   
    228. public DbDataReader ExecuteReader(DbCommand cmd)  
    229.   
    230. {  
    231.   
    232. cmd.Connection.Open();  
    233.   
    234. DbDataReader reader = cmd.ExecuteReader(CommandBehavior.CloseConnection);  
    235.   
    236. return reader;  
    237.   
    238. }  
    239.   
    240. public int ExecuteNonQuery(DbCommand cmd)  
    241.   
    242. {  
    243.   
    244. cmd.Connection.Open();  
    245.   
    246. int ret = cmd.ExecuteNonQuery();  
    247.   
    248. cmd.Connection.Close();  
    249.   
    250. return ret;  
    251.   
    252. }  
    253.   
    254.   
    255. public object ExecuteScalar(DbCommand cmd)  
    256.   
    257. {  
    258.   
    259. cmd.Connection.Open();  
    260.   
    261. object ret = cmd.ExecuteScalar();  
    262.   
    263. cmd.Connection.Close();  
    264.   
    265. return ret;  
    266.   
    267. }  
    268.  
    269. #endregion  
    270.  
    271. #region 执行事务  
    272.   
    273. public DataSet ExecuteDataSet(DbCommand cmd, Trans t)  
    274.   
    275. {  
    276.   
    277. cmd.Connection = t.DbConnection;  
    278.   
    279. cmd.Transaction = t.DbTrans;  
    280.   
    281. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    282.   
    283. DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();  
    284.   
    285. dbDataAdapter.SelectCommand = cmd;  
    286.   
    287. DataSet ds = new DataSet();  
    288.   
    289. dbDataAdapter.Fill(ds);  
    290.   
    291. return ds;  
    292.   
    293. }  
    294.   
    295.   
    296. public DataTable ExecuteDataTable(DbCommand cmd, Trans t)  
    297.   
    298. {  
    299.   
    300. cmd.Connection = t.DbConnection;  
    301.   
    302. cmd.Transaction = t.DbTrans;  
    303.   
    304. DbProviderFactory dbfactory = DbProviderFactories.GetFactory(DbHelper.dbProviderName);  
    305.   
    306. DbDataAdapter dbDataAdapter = dbfactory.CreateDataAdapter();  
    307.   
    308. dbDataAdapter.SelectCommand = cmd;  
    309.   
    310. DataTable dataTable = new DataTable();  
    311.   
    312. dbDataAdapter.Fill(dataTable);  
    313.   
    314. return dataTable;  
    315.   
    316. }  
    317.   
    318.   
    319. public DbDataReader ExecuteReader(DbCommand cmd, Trans t)  
    320.   
    321. {  
    322.   
    323. cmd.Connection.Close();  
    324.   
    325. cmd.Connection = t.DbConnection;  
    326.   
    327. cmd.Transaction = t.DbTrans;  
    328.   
    329. DbDataReader reader = cmd.ExecuteReader();  
    330.   
    331. DataTable dt = new DataTable();  
    332.   
    333. return reader;  
    334.   
    335. }  
    336.   
    337. public int ExecuteNonQuery(DbCommand cmd, Trans t)  
    338.   
    339. {  
    340.   
    341. cmd.Connection.Close();  
    342.   
    343. cmd.Connection = t.DbConnection;  
    344.   
    345. cmd.Transaction = t.DbTrans;  
    346.   
    347. int ret = cmd.ExecuteNonQuery();  
    348.   
    349. return ret;  
    350.   
    351. }  
    352.   
    353.   
    354. public object ExecuteScalar(DbCommand cmd, Trans t)  
    355.   
    356. {  
    357.   
    358. cmd.Connection.Close();  
    359.   
    360. cmd.Connection = t.DbConnection;  
    361.   
    362. cmd.Transaction = t.DbTrans;  
    363.   
    364. object ret = cmd.ExecuteScalar();  
    365.   
    366. return ret;  
    367.   
    368. }  
    369.  
    370. #endregion  
    371.   
    372. }  
    373.   
    374.   
    375. public class Trans : IDisposable  
    376.   
    377. {  
    378.   
    379. private DbConnection conn;  
    380.   
    381. private DbTransaction dbTrans;  
    382.   
    383. public DbConnection DbConnection  
    384.   
    385. {  
    386.   
    387. get { return this.conn; }  
    388.   
    389. }  
    390.   
    391. public DbTransaction DbTrans  
    392.   
    393. {  
    394.   
    395. get { return this.dbTrans; }  
    396.   
    397. }  
    398.   
    399.   
    400. public Trans()  
    401.   
    402. {  
    403.   
    404. conn = DbHelper.CreateConnection();  
    405.   
    406. conn.Open();  
    407.   
    408. dbTrans = conn.BeginTransaction();  
    409.   
    410. }  
    411.   
    412. public Trans(string connectionString)  
    413.   
    414. {  
    415.   
    416. conn = DbHelper.CreateConnection(connectionString);  
    417.   
    418. conn.Open();  
    419.   
    420. dbTrans = conn.BeginTransaction();  
    421.   
    422. }  
    423.   
    424. public void Commit()  
    425.   
    426. {  
    427.   
    428. dbTrans.Commit();  
    429.   
    430. this.Colse();  
    431.   
    432. }  
    433.   
    434.   
    435. public void RollBack()  
    436.   
    437. {  
    438.   
    439. dbTrans.Rollback();  
    440.   
    441. this.Colse();  
    442.   
    443. }  
    444.   
    445.   
    446. public void Dispose()  
    447.   
    448. {  
    449.   
    450. this.Colse();  
    451.   
    452. }  
    453.   
    454.   
    455. public void Colse()  
    456.   
    457. {  
    458.   
    459. if (conn.State == System.Data.ConnectionState.Open)  
    460.   
    461. {  
    462.   
    463. conn.Close();  
    464.   
    465. }  
    466.   
    467. }  
    468.   
    469.   
    470. }  
    471.   
    472. }  

    2、直接执行sql语句

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetSqlStringCommond("insert t1 (id)values(‘?haha‘?)");  
    4.   
    5. db.ExecuteNonQuery(cmd);  

    3、执行存储过程

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetStoredProcCommond("t1_insert");  
    4.   
    5. db.AddInParameter(cmd, "@id", DbType.String, "heihei");  
    6.   
    7. db.ExecuteNonQuery(cmd);  

    4、返回DataSet

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetSqlStringCommond("select * from t1");  
    4.   
    5. DataSet ds = db.ExecuteDataSet(cmd);  

    5、返回DataTable

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetSqlStringCommond("t1_findall");  
    4.   
    5. DataTable dt = db.ExecuteDataTable(cmd);  

    6、输入参数/输出参数/返回值的使用(比较重要哦)

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetStoredProcCommond("t2_insert");  
    4.   
    5. db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);  
    6.   
    7. db.AddOutParameter(cmd, "@outString", DbType.String, 20);  
    8.   
    9. db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);  
    10.   
    11.   
    12. db.ExecuteNonQuery(cmd);  
    13.   
    14.   
    15. string s = db.GetParameter(cmd, "@outString").Value as string;   
    16.   
    17. int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);   

    7、DataReader使用

    [c-sharp] view plain copy
     
    1. DbHelper db = new DbHelper();  
    2.   
    3. DbCommand cmd = db.GetStoredProcCommond("t2_insert");  
    4.   
    5. db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);  
    6.   
    7. db.AddOutParameter(cmd, "@outString", DbType.String, 20);  
    8.   
    9. db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);  
    10.   
    11.   
    12. using (DbDataReader reader = db.ExecuteReader(cmd))  
    13.   
    14. {  
    15.   
    16. dt.Load(reader);  
    17.   
    18. }   
    19.   
    20. string s = db.GetParameter(cmd, "@outString").Value as string;   
    21.   
    22. int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);   

    8、事务的使用.(项目中需要将基本的数据库操作组合成一个完整的业务流时,代码级的事务是必不可少的哦)

    以上我们好像没有指定数据库连接字符串,大家如果看下DbHelper的代码,就知道要使用它必须在config中配置两个参数,如下:

    [c-sharp] view plain copy
     
    1. pubic void DoBusiness()  
    2.   
    3. {  
    4.   
    5. using (Trans t = new Trans())  
    6.   
    7. {  
    8.   
    9. try  
    10.   
    11. {  
    12.   
    13. D1(t);  
    14.   
    15. throw new Exception();  
    16.   
    17. D2(t);  
    18.   
    19. t.Commit();  
    20.   
    21. }  
    22.   
    23. catch  
    24.   
    25. {  
    26.   
    27. t.RollBack();  
    28.   
    29. }  
    30.   
    31. }  
    32.   
    33. }  
    34.   
    35. public void D1(Trans t)  
    36.   
    37. {  
    38.   
    39. DbHelper db = new DbHelper();  
    40.   
    41. DbCommand cmd = db.GetStoredProcCommond("table_insert");  
    42.   
    43. db.AddInParameter(cmd, "@timeticks", DbType.Int64, DateTime.Now.Ticks);  
    44.   
    45. db.AddOutParameter(cmd, "@outString", DbType.String, 20);  
    46.   
    47. db.AddReturnParameter(cmd, "@returnValue", DbType.Int32);  
    48.   
    49.   
    50. if (t == null) db.ExecuteNonQuery(cmd);  
    51.   
    52. else db.ExecuteNonQuery(cmd,t);  
    53.   
    54.   
    55. string s = db.GetParameter(cmd, "@outString").Value as string;  
    56.   
    57. int r = Convert.ToInt32(db.GetParameter(cmd, "@returnValue").Value);  
    58.   
    59. }  
    60.   
    61. public void D2(Trans t)  
    62.   
    63. {  
    64.   
    65. DbHelper db = new DbHelper();  
    66.   
    67. DbCommand cmd = db.GetSqlStringCommond("insert table (id)values(@id)");   
    68.   
    69. if (t == null) db.ExecuteNonQuery(cmd);  
    70.   
    71. else db.ExecuteNonQuery(cmd, t);  
    72.   
    73. }  
     
  • 相关阅读:
    asp.net mvc(2013424)——基本知识
    asp.net mvc(2013425)——使用模板页
    jquery实现tab切换核心代码
    asp.net mvc(2013422 )——准备入门
    也说C#串行化
    Net Assembly.GetExecutingAssembly() 和 Assembly.GetCallingAssembly()的区别
    log (一)
    C# 重载和从写的区别
    log4net
    C# 反射
  • 原文地址:https://www.cnblogs.com/yanyao/p/5611284.html
Copyright © 2011-2022 走看看