zoukankan      html  css  js  c++  java
  • 手写SqlHelper

    SqlHelper是一个基于.NET Framework的数据库操作组件。组件中包含数据库操作方法,SqlHelper有很多版本,主要以微软一开始发布的SqlHelper类,后面包含进了Enterprise Library开源包中了。还有一个主要版本是dbhelper.org开源的sqlhelper组件,优点是简洁,高性能,不仅仅支持sqlserver,同时支持sqlserver、oracle、access、Mysql数据库,也是一个开源项目,提供免费下载。

    在配置文件(app.config)中添加数据库地址连接信息

    <connectionStrings>
        <add name="connstr" connectionString="data source=10.10.198.111;Initial Catalog=systemconfig;user id=sa;password=sa"/>
      </connectionStrings>

    在项目中添加SqlHelper类

            //获取连接地址
            private static readonly string connstr = ConfigurationManager.ConnectionStrings["connstr"].ConnectionString;

    ExecuteScalar。此方法返回一个值。该值始终是该命令返回的第一行的第一列。

            /// <summary>
            /// 查询该值始终是该命令返回的第一行的第一列
            /// </summary>
            /// <param name="sql">执行sql</param>
            /// <param name="parameters">sql执行参数</param>
            /// <returns></returns>
            public static object ExecuteScalar(string sql, params SqlParameter[] parameters)
            {
                using (SqlConnection cnn = new SqlConnection(connstr))
                {
                    cnn.Open();
                    using (SqlCommand cmd = cnn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
                        return cmd.ExecuteScalar();
                    }
                }
            }

    查询数据

            /// <summary>
            /// 查询数据
            /// </summary>
            /// <param name="sql"></param>
            /// <param name="parameters"></param>
            /// <returns></returns>
            public static DataTable ExecuteDateTable(string sql, params SqlParameter[] parameters)
            {
                using (SqlConnection cnn = new SqlConnection(connstr))
                {
                    cnn.Open();
                    using (SqlCommand cmd = cnn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
                        SqlDataAdapter apter = new SqlDataAdapter(cmd);
                        DataSet ds = new DataSet();
                        apter.Fill(ds);
                        return ds.Tables[0];
                    }
                }
            }

     ExecuteNonQuery。此方法用于执行不返回任何行或值的命令。这些命令通常用于执行数据库更新,但也可用于返回存储过程的输出参数。

    public static int ExecuteNonQuery(string sql, params SqlParameter[] parameters)
            {
                using (SqlConnection cnn = new SqlConnection(connstr))
                {
                    cnn.Open();
                    using (SqlCommand cmd = cnn.CreateCommand())
                    {
                        cmd.CommandText = sql;
                        cmd.Parameters.AddRange(parameters);
                        return cmd.ExecuteNonQuery();
                    }
                }
            }
  • 相关阅读:
    系统分析师思维导图
    系统分析师案例分析知识点——虚拟内存篇
    系统分析师案例分析知识点——进程管理问题
    系统分析师案例分析知识点——进程同步问题
    200行代码实现RPC框架
    由vue3引起的一段值得记录经历
    PetaPoco在ASP.NET Core 2.2中使用注入方式访问数据库
    在.net core 中PetaPoco结合EntityFrameworkCore使用codefirst方法进行开发
    Quartz.NET的简单任务管理类
    System.Action的使用(lambda 表达式)
  • 原文地址:https://www.cnblogs.com/tuqun/p/3635474.html
Copyright © 2011-2022 走看看