详解使用C#编写SqlHelper类
无聊的周末,学习、编码无力。想找点事干但又不知道干点什么,猛然发现自己学过的SqlHelper快忘记了。于是乎虎躯一震心想怎能如此堕落下去,立马打开电脑,双手摸上键盘。写下此文作为学习过程中的复习,并分享出知识(顺便打发时间-^.^-)。
下面开始正文
这里以控制台程序为案例。首先我们需要先配置一下连接字符串,我们需要在app.config文件中增加如下节点:
1.接着需要创建一个名为SqlHepler类,然后创建一个方法来获取app.config文件中配置的连接字符串。
publicstaticstringGetSqlConnectionString() { returnConfigurationManager. ConnectionStrings["Sql"].ConnectionString; }
2.下面来封装第一个SqlHepler方法,封装一个执行的sql返回受影响的行数。
publicstaticintExecuteNonQuery(stringsqlText,paramsSqlParameter[]parameters) { using(SqlConnectionconn=newSqlConnection(GetSqlConnectionString())) { using(SqlCommandcmd=conn.CreateCommand()) { conn.Open();//打开数据库 cmd.CommandText=sqlText;//对CommandText进行赋值 cmd.Parameters.AddRange(parameters);//对数据库使用参数进行赋值 returncmd.ExecuteNonQuery(); } } }
参数说明:sqlText:需要执行的sql脚本,parameters:需要的参数集合
该方法主要是用于执行,删除、更新和插入操作,返回受影响的行数。
3.继续封装一个查询操作,返回查询结果中的第一行第一列的值
publicstaticobjectExecuteScalar(stringsqlText,paramsSqlParameter[]parameters) { using(SqlConnectionconn=newSqlConnection(GetSqlConnectionString())) { using(SqlCommandcmd=conn.CreateCommand()) { conn.Open(); cmd.CommandText=sqlText; cmd.Parameters.AddRange(parameters); returncmd.ExecuteScalar(); } } }
参数说明:如上。
该方法的返回值第object,所以当我们查询的数据不知道是什么类型的时候可以使用该类。
4.在封装个常用的查询方法,返回一个DataTable
publicstaticDataTableExecuteDataTable(stringsqlText,paramsSqlParameter[]parameters) { using(SqlDataAdapteradapter=newSqlDataAdapter(sqlText,GetSqlConnectionString())) { DataTabledt=newDataTable(); adapter.SelectCommand.Parameters.AddRange(parameters); adapter.Fill(dt); returndt; } }
参数说明:如上。
该方法主要用于一些查询数据,dt将被填充查询出来的数据,然后返回数据。
5.最后在写封装一个查询方法,该方法返回的是一个SqlDataReader类型
publicstaticSqlDataReaderExecuteReader(stringsqlText,paramsSqlParameter[]parameters) { //SqlDataReader要求,它读取数据的时候有,它独占它的SqlConnection对象,而且SqlConnection必须是Open状态 SqlConnectionconn=newSqlConnection(GetSqlConnectionString());//不要释放连接,因为后面还需要连接打开状态 SqlCommandcmd=conn.CreateCommand(); conn.Open(); cmd.CommandText=sqlText; cmd.Parameters.AddRange(parameters); //CommandBehavior.CloseConnection当SqlDataReader释放的时候,顺便把SqlConnection对象也释放掉 returncmd.ExecuteReader(CommandBehavior.CloseConnection); }
参数说明:依旧如上。
该方法返回的SqlDataReader类型对象需要一直使用SqlConnection对象,所以不能释放。该类型读取数据是一行一行的读取。读取使用的是该类的Read()方法,返回值为bool判断数据是否为空(也就是是否读取到最后一行),该方法将自动读取下到下一条记录。
作为一个初学者,本次只是简单的介绍,并复习了一下SqlHepler类。
附上全部代码:
usingSystem.Configuration; usingSystem.Data; usingSystem.Data.SqlClient; namespaceUserInfoMgr { classSqlHelper { //////获取连接字符串 /// ///连接字符串 publicstaticstringGetSqlConnectionString() { returnConfigurationManager.ConnectionStrings["Sql"].ConnectionString; } //////封装一个执行的sql返回受影响的行数 /// ///执行的sql脚本 /// 参数集合 /// 受影响的行数 publicstaticintExecuteNonQuery(stringsqlText,paramsSqlParameter[]parameters) { using(SqlConnectionconn=newSqlConnection(GetSqlConnectionString())) { using(SqlCommandcmd=conn.CreateCommand()) { conn.Open(); cmd.CommandText=sqlText; cmd.Parameters.AddRange(parameters); returncmd.ExecuteNonQuery(); } } } //////执行sql,返回查询结果中的第一行第一列的值 /// ///执行的sql脚本 /// 参数集合 /// 查询结果中的第一行第一列的值 publicstaticobjectExecuteScalar(stringsqlText,paramsSqlParameter[]parameters) { using(SqlConnectionconn=newSqlConnection(GetSqlConnectionString())) { using(SqlCommandcmd=conn.CreateCommand()) { conn.Open(); cmd.CommandText=sqlText; cmd.Parameters.AddRange(parameters); returncmd.ExecuteScalar(); } } } //////执行sql返回一个DataTable /// ///执行的sql脚本 /// 参数集合 /// 返回一个DataTable publicstaticDataTableExecuteDataTable(stringsqlText,paramsSqlParameter[]parameters) { using(SqlDataAdapteradapter=newSqlDataAdapter(sqlText,GetSqlConnectionString())) { DataTabledt=newDataTable(); adapter.SelectCommand.Parameters.AddRange(parameters); adapter.Fill(dt); returndt; } } //////执行sql脚本 /// ///执行的sql脚本 /// 参数集合 /// 返回一个SqlDataReader publicstaticSqlDataReaderExecuteReader(stringsqlText,paramsSqlParameter[]parameters) { //SqlDataReader要求,它读取数据的时候有,它独占它的SqlConnection对象,而且SqlConnection必须是Open状态 SqlConnectionconn=newSqlConnection(GetSqlConnectionString());//不要释放连接,因为后面还需要连接打开状态 SqlCommandcmd=conn.CreateCommand(); conn.Open(); cmd.CommandText=sqlText; cmd.Parameters.AddRange(parameters); //CommandBehavior.CloseConnection当SqlDataReader释放的时候,顺便把SqlConnection对象也释放掉 returncmd.ExecuteReader(CommandBehavior.CloseConnection); } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。