c# SqlServer SqlHelper工具类

 class SqlHelper
    {
        public static string GetSqlConnectionString()
        {
            return Utils.connectStr;
        }
        /// <summary>
        /// 适合增删改操作,返回影响条数
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="parameters">参数</param>
        /// <returns>返回影响条数</returns>
        public static int ExecuteNonQuery(string sql, params SqlParameter[] parameters)
        {
            using (SqlConnection conn = new SqlConnection(GetSqlConnectionString()))
            {
                using (SqlCommand comm = conn.CreateCommand())
                {
                    conn.Open();
                    comm.CommandText = sql;
                    comm.Parameters.AddRange(parameters);
                    return comm.ExecuteNonQuery();
                }
            }
        }
        /// <summary>
        /// 查询操作,返回查询结果中的第一行第一列的值
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="parameters">参数</param>
        /// <returns>返回查询结果中的第一行第一列的值</returns>
        public static object ExecuteScalar(string sql, params SqlParameter[] parameters)
        {
            using (SqlConnection conn = new SqlConnection(GetSqlConnectionString()))
            {
                using (SqlCommand comm = conn.CreateCommand())
                {
                    conn.Open();
                    comm.CommandText = sql;
                    comm.Parameters.AddRange(parameters);
                    return comm.ExecuteScalar();
                }
            }
        }

        /// <summary>
        /// Adapter调整,查询操作,返回DataTable
        /// </summary>
        /// <param name="sql">sql语句</param>
        /// <param name="parameters">参数</param>
        /// <returns>返回DataTable</returns>
        public static DataTable ExecuteDataTable(string sql, params SqlParameter[] parameters)
        {
            using (SqlDataAdapter adapter = new SqlDataAdapter(sql, GetSqlConnectionString()))
            {
                DataTable dt = new DataTable();
                adapter.SelectCommand.Parameters.AddRange(parameters);
                adapter.Fill(dt);
                return dt;
            }
        }

        public static SqlDataReader ExecuteReader(string sqlText, params SqlParameter[] parameters)
        {
            //SqlDataReader要求,它读取数据的时候有,它独占它的SqlConnection对象,而且SqlConnection必须是Open状态
            SqlConnection conn = new SqlConnection(GetSqlConnectionString());//不要释放连接,因为后面还需要连接打开状态
            SqlCommand cmd = conn.CreateCommand();
            conn.Open();
            cmd.CommandText = sqlText;
            cmd.Parameters.AddRange(parameters);
            //CommandBehavior.CloseConnection当SqlDataReader释放的时候,顺便把SqlConnection对象也释放掉
            return cmd.ExecuteReader(CommandBehavior.CloseConnection);
        }
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的 C# 工具类,用于连接 SQL Server 数据库: ```csharp using System; using System.Data.SqlClient; public class SqlHelper { // 连接字符串 private string connectionString; // 构造函数 public SqlHelper(string connectionString) { this.connectionString = connectionString; } // 执行 SQL 命令,返回受影响的行数 public int ExecuteNonQuery(string sql) { using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); using (SqlCommand command = new SqlCommand(sql, connection)) { return command.ExecuteNonQuery(); } } } // 执行 SQL 查询,返回 SqlDataReader 对象 public SqlDataReader ExecuteReader(string sql) { SqlConnection connection = new SqlConnection(connectionString); connection.Open(); SqlCommand command = new SqlCommand(sql, connection); SqlDataReader reader = command.ExecuteReader(System.Data.CommandBehavior.CloseConnection); return reader; } // 执行 SQL 查询,返回单个结果 public object ExecuteScalar(string sql) { using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); using (SqlCommand command = new SqlCommand(sql, connection)) { return command.ExecuteScalar(); } } } } ``` 使用示例: ```csharp // 连接字符串 string connectionString = "Server=(local);Database=MyDatabase;User ID=MyUsername;Password=MyPassword;"; // 创建 SqlHelper 对象 SqlHelper sqlHelper = new SqlHelper(connectionString); // 执行 SQL 命令 sqlHelper.ExecuteNonQuery("INSERT INTO MyTable (Column1, Column2) VALUES ('Value1', 'Value2')"); // 执行 SQL 查询 SqlDataReader reader = sqlHelper.ExecuteReader("SELECT * FROM MyTable"); while (reader.Read()) { // 读取数据 string column1 = reader.GetString(0); string column2 = reader.GetString(1); } // 执行 SQL 查询,返回单个结果 object result = sqlHelper.ExecuteScalar("SELECT COUNT(*) FROM MyTable"); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值