手写SqlHelper

时间:2023-03-09 15:10:43
手写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[];
}
}
}

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();
}
}
}