首页 / C# / C# SqlHelper
C# SqlHelper
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C# SqlHelper,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含4322字,纯文字阅读大概需要7分钟。
内容图文
System; using System.Collections.Generic; using System.Configuration; using System.Data; using System.Data.SqlClient; using System.Linq; using System.Text; using System.Threading.Tasks; namespace CarHailing.Base { /// <summary> /// 数据库帮助类 /// </summary> public class SqlHelp { /// <summary> /// 创建一个已打开的连接 /// </summary> /// <returns></returns> private static SqlConnection CreateConn() { SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["conn"].ConnectionString); conn.Open(); return conn; } /// <summary> /// 执行sql语句,返回受影响的行数 /// </summary> /// <param name="sql"></param> /// <returns></returns> public static int ExecuteNonQuery(string sql) { return ExecuteNonQuery(sql, null); } /// <summary> /// 执行sql语句,返回受影响的行数 /// </summary> /// <param name="sql"></param> /// <returns></returns> public static int ExecuteNonQuery(string sql, SqlParameter[] ps) { SqlConnection conn = CreateConn(); SqlCommand cmd = new SqlCommand(sql, conn); try { if (ps != null) { cmd.Parameters.AddRange(ps); } return cmd.ExecuteNonQuery(); } catch (Exception ex) { return 0; } finally { conn.Close(); } } /// <summary> /// 执行sql语句,返回一个结果表 /// </summary> /// <param name="sql"></param> /// <returns></returns> public static DataTable ExecuteSelectDataTable(string sql) { return ExecuteSelectDataTable(sql, null); } /// <summary> /// 执行sql语句,返回一个结果表 /// </summary> /// <param name="sql"></param> /// <param name="ps"></param> /// <returns></returns> public static DataTable ExecuteSelectDataTable(string sql, SqlParameter[] ps = null) { SqlConnection conn = CreateConn(); SqlCommand cmd = new SqlCommand(sql, conn); try { if (ps != null) { cmd.Parameters.AddRange(ps); } //SqlDataAdapter sda = new SqlDataAdapter(cmd); SqlDataReader read = cmd.ExecuteReader(); DataTable table = new DataTable(); table.Load(read); //DataSet ds = new DataSet(); //sda.Fill(ds); return table; } finally { conn.Close(); } } /// <summary> /// /// </summary> /// <param name="sql"></param> /// <returns></returns>decimal public static DataTable ExecuteSelectPageDataTable(string sql, ref SqlParameter[] ps) { SqlConnection conn = CreateConn(); SqlCommand cmd = new SqlCommand(sql, conn); cmd.CommandType = CommandType.StoredProcedure; try { cmd.Parameters.AddRange(ps); SqlDataAdapter sda = new SqlDataAdapter(cmd); DataSet ds = new DataSet(); sda.Fill(ds); return ds.Tables[0]; } catch (SqlException ex) { throw ex; } finally { conn.Close(); } } //public static SqlDataReader ExecuteReader(string cmdText, CommandType cmdType, params SqlParameter[] cmdParms) //{ // SqlCommand cmd = new SqlCommand(); // SqlConnection conn = CreateConn(); // try // { // ProCommand(cmd, conn, cmdText, cmdType, cmdParms); // SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection); // //cmd.Parameters.Clear();//放到这里,返回参数会被清空。 // return rdr; // } // catch // { // conn.Close(); // throw; // } //} /// <summary> /// 分页读取数据 /// </summary> /// <param name="query">select查询语句</param> /// <param name="pageSize">每页显示数据数</param> /// <param name="PageIndex">当前页码</param> /// <param name="dt">存储数据的DataTable实例</param> public static void PageDataTable(string query, int pageSize, int PageIndex, DataTable dt) { //读取数据的开始索引 long startIndex = (PageIndex - 1) * pageSize; //读取数据的结束索引 long endIndex = PageIndex * pageSize - 1; //DataReader读取的当前数据行的索引 long readToIndex = -1; using (SqlConnection conn = CreateConn()) { SqlCommand cmd = new SqlCommand(query, conn); //conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); //数据源中的列数 int cols = dr.VisibleFieldCount; //构造DataTable结构 for (int i = 0; i < cols; i++) { dt.Columns.Add(new DataColumn(dr.GetName(i), dr.GetFieldType(i))); } //读取数据,将数据一行一行添加到DataTable while (dr.Read()) { readToIndex++; //当DataReader指针在开始索引和结束索引闭区间时才读取数据构造DataRow //并添加到DataTable if (readToIndex >= startIndex && readToIndex <= endIndex) { DataRow row = dt.NewRow(); for (int i = 0; i < cols; i++) { row[i] = dr[i]; } dt.Rows.Add(row); } } dr.Close(); } } } }
C# SqlHelper
标签:lex star ams color names ada class 构造 space
本文系统来源:https://www.cnblogs.com/zhang1f/p/11106070.html
内容总结
以上是互联网集市为您收集整理的C# SqlHelper全部内容,希望文章能够帮你解决C# SqlHelper所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。