C#.NET中现在用的SqlHelper操作方法集合【收藏版】

http://www.cnblogs.com/nianyuwen/

  1 http://www.cnblogs.com/nianyuwen/
  2 
  3 using System;
  4 using System.Collections.Generic;
  5 using System.Linq;
  6 using System.Text;
  7 using System.Data;
  8 using System.Data.SqlClient;
  9 using System.Configuration;
 10 namespace MSBDAL
 11 {
 12     /*
 13      * Descrption:数据库常用操作方法合集
 14      * Author:nianyuwen
 15      * Time:2012-03-15
 16      * MSN:nianyuwen@live.com
 17      * WebUrl:http://www.cnblogs.com/nianyuwen/
 18      */
 19    public  class SqlHelper
 20     {
 21        public SqlHelper()
 22        {
 23            //TODO:构造数据库常用操作方法集
 24        }
 25        private static SqlConnection connection;
 26        private static string connectionString;
 27        public static SqlConnection Connection
 28        {
 29            get
 30            {
 31                //string connectionString = ConfigurationManager.ConnectionStrings["stock"].ConnectionString;
 32                //"Data Source=.;Initial Catalog=StockBank;Persist Security Info=True;User ID=sa;pwd=123";
 33                connectionString = ConfigurationSettings.AppSettings["ConstrSQL"].ToString();
 34                
 35                if (connection == null)
 36                {
 37                    connection = new SqlConnection(connectionString);
 38                    connection.Open();
 39                }
 40                else if (connection.State == System.Data.ConnectionState.Closed)
 41                {
 42                    connection.Open();
 43                }
 44                else if (connection.State == System.Data.ConnectionState.Broken)
 45                {
 46                    connection.Close();
 47                    connection.Open();
 48                }
 49                return connection;
 50            }
 51        }
 52 
 53        public static int ExecuteCommand(string safeSql)
 54        {
 55            SqlCommand cmd = new SqlCommand(safeSql, Connection);
 56            int result = cmd.ExecuteNonQuery();
 57            return result;
 58        }
 59       /// <summary>
 60       /// 带参数的执行命令
 61       /// </summary>
 62       /// <param name="sql">SQL命令</param>
 63       /// <param name="values">返回VALUE值</param>
 64       /// <returns></returns>
 65        public static int ExecuteCommand(string sql, params SqlParameter[] values)
 66        {
 67            SqlCommand cmd = new SqlCommand(sql, Connection);
 68            cmd.Parameters.AddRange(values);
 69            return cmd.ExecuteNonQuery();
 70        }
 71        /// <summary>
 72        /// 返回影响记录数
 73        /// </summary>
 74        /// <param name="safeSql"></param>
 75        /// <returns></returns>
 76        public static int GetScalar(string safeSql)
 77        {
 78            SqlCommand cmd = new SqlCommand(safeSql, Connection);
 79            int result = Convert.ToInt32(cmd.ExecuteScalar());
 80            return result;
 81        }
 82 
 83        public static int GetScalar(string sql, params SqlParameter[] values)
 84        {
 85            SqlCommand cmd = new SqlCommand(sql, Connection);
 86            cmd.Parameters.AddRange(values);
 87            int result = Convert.ToInt32(cmd.ExecuteScalar());
 88            return result;
 89        }
 90 
 91        public static SqlDataReader GetReader(string safeSql)
 92        {
 93            SqlCommand cmd = new SqlCommand(safeSql, Connection);
 94            SqlDataReader reader = cmd.ExecuteReader();
 95            return reader;
 96        }
 97 
 98        public static SqlDataReader GetReader(string sql, params SqlParameter[] values)
 99        {
100            SqlCommand cmd = new SqlCommand(sql, Connection);
101            cmd.Parameters.AddRange(values);
102            SqlDataReader reader = cmd.ExecuteReader();
103            return reader;
104        }
105 
106        public static DataTable GetDataSet(string safeSql)
107        {
108            DataSet ds = new DataSet();
109            SqlCommand cmd = new SqlCommand(safeSql, Connection);
110            SqlDataAdapter da = new SqlDataAdapter(cmd);
111            da.Fill(ds);
112            return ds.Tables[0];
113        }
114 
115        public static DataTable GetDataSet(string sql, params SqlParameter[] values)
116        {
117            DataSet ds = new DataSet();
118            SqlCommand cmd = new SqlCommand(sql, Connection);
119            cmd.Parameters.AddRange(values);
120            SqlDataAdapter da = new SqlDataAdapter(cmd);
121            da.Fill(ds);
122            return ds.Tables[0];
123        }
124 
125        /// <summary>
126        /// 获得数据集
127        /// </summary>
128        public static DataSet GetDataSet(string sql, string table)
129        {
130            DataSet ds = new DataSet();
131            SqlCommand cmd = new SqlCommand(sql, Connection);
132            SqlDataAdapter da = new SqlDataAdapter(cmd);
133            da.Fill(ds, table);
134            return ds;
135        }
136 
137        public static DataSet GetDataSet(string sql, string table, params SqlParameter[] values)
138        {
139            DataSet ds = new DataSet();
140            SqlCommand cmd = new SqlCommand(sql, Connection);
141            cmd.Parameters.AddRange(values);
142            SqlDataAdapter da = new SqlDataAdapter(cmd);
143            da.Fill(ds, table);
144            return ds;
145        }
146     }
147 }

 

 

转载于:https://www.cnblogs.com/zcds-jk/archive/2012/04/27/4345327.html

SqlHelper源码及使用实例下载 SqlHelper 类实现详细信息 SqlHelper 类用于通过一组静态方法来封装数据访问功能。该类不能被继承或实例化,因此将其声明为包含专用构造函数的不可继承类。 在 SqlHelper实现的每种方法都提供了一组一致的重载。这提供了一种很好的使用 SqlHelper 类来执行命令的模式,同时为开发人员选择访问数据的方式提供了必要的灵活性。每种方法的重载都支持不同的方法参数,因此开发人员可以确定传递连接、事务和参数信息的方式。在 SqlHelper实现的方法包括: ExecuteNonQuery。此方法用于执行不返回任何行或值的命令。这些命令通常用于执行数据库更新,但也可用于返回存储过程的输出参数。 ExecuteReader。此方法用于返回 SqlDataReader 对象,该对象包含由某一命令返回的结果集。 ExecuteDataset。此方法返回 DataSet 对象,该对象包含由某一命令返回的结果集。 ExecuteScalar。此方法返回一个值。该值始终是该命令返回的第一行的第一列。 ExecuteXmlReader。此方法返回 FOR XML 查询的 XML 片段。 除了这些公共方法外,SqlHelper 类还包含一些专用函数,用于管理参数和准备要执行的命令。不管客户端调用什么样的方法实现,所有命令都通过 SqlCommand 对象来执行。在 SqlCommand 对象能够被执行之前,所有参数都必须添加到 Parameters 集合,并且必须正确设置 Connection、CommandType、CommandText 和 Transaction 属性。SqlHelper的专用函数主要用于提供一种一致的方式,以便向 SQL Server 数据库发出命令,而不考虑客户端应用程序调用的重载方法实现。SqlHelper的专用实用程序函数包括: SqlHelper是非常方便的数据库操作函数,功能强大,使用起来非常简单,免去很多复杂的数据库操作的代码,在多层应用及面向对象开发都有很多应用 SqlHelper源码带有详细的说明,示例有原始的示例Sql语句 主要包括以下操作: 简单SQL语句(ExcuteSql) 带参数的简单SQL语句(ExcuteSQLParm) 简单存储过程 (ExcuteProc) 带参数的存储过程(ExcuteProcParm) 只返回一个字段 (ExcuteScalar) 返回数据集(ExcuteReader) 数据库有示例数据及存储过程updateTable\updateTableByParm,大家可以自行修改测试
using System; using System.Collections; using System.Collections.Generic; using System.Text; using System.Data; using System.Data.SqlClient; using System.Configuration; namespace MyOfficeDAL { public static class DBHelper { private static SqlConnection connection; public static SqlConnection Connection { get { string connectionString = ConfigurationManager.ConnectionStrings["MyOfficeConnectionString"].ConnectionString; connection = new SqlConnection(connectionString); if (connection == null) { connection.Open(); } else if (connection.State == System.Data.ConnectionState.Closed) { connection.Open(); } else if (connection.State == System.Data.ConnectionState.Broken) { connection.Close(); connection.Open(); } return connection; } } public static int ExecuteCommand(string safeSql) { SqlCommand cmd = new SqlCommand(safeSql, Connection); int result = cmd.ExecuteNonQuery(); return result; } public static int ExecuteCommand(string sql, params SqlParameter[] values) { SqlCommand cmd = new SqlCommand(sql, Connection); cmd.Parameters.AddRange(values); return cmd.ExecuteNonQuery(); } public static string ReturnStringScalar(string safeSql) { SqlCommand cmd = new SqlCommand(safeSql, Connection); try { string result = cmd.ExecuteScalar().ToString(); return result; } catch (Exception ex) { return "0"; } connection.Close(); } public static int GetScalar(string safeSql) { SqlCommand cmd = new SqlCommand(safeSql, Connection); try { int result = Convert.ToInt32(cmd.ExecuteScalar()); return result; } catch (Exception e) { return 0; } connection.Close(); } public static int GetScalar(string sql, params SqlParameter[] values) { SqlCommand cmd = new SqlCommand(sql, Connection); cmd.Parameters.AddRange(values); int result = Convert.ToInt32(cmd.ExecuteScalar()); return result; connection.Close(); } public static SqlDataReader GetReader(string safeSql) { SqlCommand cmd = new SqlCommand(safeSql, Connection); SqlDataReader reader = cmd.ExecuteReader(); return reader; reader.Close(); reader.Dispose(); } public static SqlDataReader GetReader(string sql, params SqlParameter[] values) { SqlCommand cmd = new SqlCommand(sql, Connection); cmd.Parameters.AddRange(values); SqlDataReader reader = cmd.ExecuteReader(); return reader; reader.Close(); reader.Dispose(); } public static DataTable GetDataSet(string safeSql) { DataSet ds = new DataSet(); SqlCommand cmd = new SqlCommand(safeSql, Connection); SqlDataAdapter da = new SqlDataAdapter(cmd); da.Fill(ds); connection.Close(); connection.Dispose(); return ds.Tables[0]; } public static DataTable GetDataSet(string sql, params SqlParameter[] values) { DataSet ds = new DataSet(); SqlCommand cmd = new SqlCommand(sql, Connection); cmd.Parameters.AddRange(values); SqlDataAdapter da = new SqlDataAdapter(cmd); da.Fill(ds); connection.Close(); connection.Dispose(); return ds.Tables[0]; } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值