DBhelper

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DBhelper相关的知识,希望对你有一定的参考价值。

关于asp.net中的DBhelper 是干什么用的,我怎么调不出来啊,我的语句是:num=DBhelper.execscalar(viewstate["countsql"].tostring());
可是我调不出DBhelper啊,这个我想应该是access中的,我书上用这个就是用access数据库,我用的是sql,我认为应该有东西可以代替DBhelper吧,这样就能适合sql了,请问这些都是如何实现,
当我敲击DBhelper的时候并没有单词提示啊,我认为我肯定有什么错误的地方,像这种应该有单词提示啊!

参考技术A DBhelper顾名思义,DB即数据库,helper帮助!肯定是操作数据库的一个被封装好的类,里面封装了绝大部分操作数据库的方法,有了它而你只需要一行语句即可完成一项数据库的操作。

你这上面的num=DBhelper.execscalar(viewstate["countsql"].tostring());

exec这个估计是个调用存储过程的东东,而scalar这个好理解吧,数据库中查询列的语句,返回是一个int。从这里可以看出,他是调用一个存储过程来计算符合条件某列的总数或者其它相关的内容!
参考技术B DBhelper 可没这个东西,估计是别人自己写的。
数据访问模块SqlHelper倒有一个,微软提供的,专用与SqlServer的访问,
可以将它改写用于Access,网上有改写的或者我可以发给你!
参考技术C 访问Sqlserver可以用System.Data.SqlClient命名空间中的
sqlconnection和sqlcommand来访问数据库。
详细的你可以去查查MSDN
参考技术D 微软提供了一个类库叫SQLHELPER,你可以用他,官网有或者直接搜

dbhelper

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Configuration;
using System.Data.SqlClient;
using System.Data;//using: 引入命名空间

namespace DBHelper
{
public static class DBHelper
{
//Web.config 配置
// <?xml version="1.0"?>
//
// <configuration>
//
// <!--指定配置节和命名空间声明。clear:移除对继承的节和节组的所有引用,只允许由当前 section 和 sectionGroup 元素添加的节和节组。remove:移除对继承的节和节组的引用。section:定义配置节处理程序与配置元素之间的关联。sectionGroup:定义配置节处理程序与配置节之间的关联。-->
// <configSections>
// ............
// </configSections>
//
// <!--appSettings是应用程序设置,可以定义应用程序的全局常量设置等信息-->
// <appSettings>
// ..............
// </appSettings>
//
// <!--连接字符串设置-->
// <connectionStrings>
// <add name="strCon" connectionString="Data Source=CUSTDB;user=HISSG_AG;password=HISSG_AG;"/>
// </connectionStrings>
//
// <system.web>

// </system.web>
// .................
// .................
// </configuration>


//要引入using System.Configuration命名空间
private static readonly string connectionString = ConfigurationManager.ConnectionStrings["strCon"].ConnectionString;

/// <summary>
/// 执行SQL语句,返回受影响的行数(用于insert,delete,update等)
/// </summary>
/// <param name="strSQL">SQL语句</param>
/// <returns>受影响的行数</returns>
public static int ExecuteSql(string strSQL)
{
//using: 释放资源
//SqlConnection: 连接数据源
//connectionString:用于连接数据源的字符串
using (SqlConnection conn = new SqlConnection(connectionString))
{
//SqlCommand对数据源执行SQl命令
//SqlCommand(CommandText, CommandString):strSQL需执行的SQL命令字符串,conn指定执行SQL命令需连接的数据源
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
int rows = cmd.ExecuteNonQuery();//执行SQL语句,返回受影响的行数。如rows>0,说明执行成功
return rows;
}
catch (System.Data.SqlClient.SqlException e)
{
conn.Close();//出异常,关闭数据源连接
throw e;
}
}
}
}

/// <summary>
/// 执行带参数的非查询SQL
/// </summary>
/// <param name="strSQL">SQL语句</param>
/// <param name="values">参数</param>
/// <returns>受影响行数</returns>
public static int ExecuteCommand(string strSQL, params SqlParameter[] values)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
cmd.Parameters.AddRange(values);
int rows = cmd.ExecuteNonQuery();//执行SQL语句,返回受影响的行数。如rows>0,说明执行成功
return rows;
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}

/// <summary>
/// 执行查询SQL语句,返回SqlDataReader(只进记录集) ( 注意:调用该方法后,一定要对SqlDataReader进行Close )
/// </summary>
/// <param name="strSQL">查询语句</param>
/// <returns>SqlDataReader</returns>
public static SqlDataReader ExecuteReader(string strSQL)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
//CommandBehavior.CloseConnection 能够保证当SqlDataReader对象被关闭时,其依赖的连接也会被自动关闭。
SqlDataReader myReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
return myReader;
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}

/// <summary>
/// 执行带参数的查询SQL语句,返回SqlDataReader ( 注意:调用该方法后,一定要对SqlDataReader进行Close )
/// </summary>
/// <param name="strSQL">查询语句</param>
/// <param name="values">参数</param>
/// <returns>SqlDataReader</returns>
public static SqlDataReader ExecuteReader(string strSQL, params SqlParameter[] values)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
//CommandBehavior.CloseConnection 能够保证当SqlDataReader对象被关闭时,其依赖的连接也会被自动关闭。
cmd.Parameters.AddRange(values);
SqlDataReader myReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
return myReader;
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}


///////DataReader和DataSet的区别
///////1.获取数据的方式:
/////// DataReader(在线-一直占用SqlConnection连接,其它操作就可以不可使用,占用内存较小)
/////// DataSet(离线-将数据一次性读入内存,然后断开连接,其它操作就可以使用,比较消耗资源)
///////2.获取数据的机制
/////// DataReader是通过IDbCommand.ExecuteReader来读取数据。
/////// DataSet则是通过DbDataAdapter.Fill来填充数据
///////3.其它区别
/////// DataReader读取速度快于DataSet。
/////// DataReader是数据提供者类,DataSet是一般性类,借助于DbDataAdapter来填充数据。
///////...............................等


/// <summary>
/// 执行查询SQL语句,返回离线记录集
/// </summary>
/// <param name="strSQL">SQL语句</param>
/// <returns>离线记录DataSet</returns>
public DataSet getDataTablebySQL(string strSQL)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
DataSet ds = new DataSet();
SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
myAdapter.Fill(ds);
return ds;
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}

/// <summary>
/// 执行带参数的查询SQL,返回离线记录集
/// </summary>
/// <param name="strSQL"></param>
/// <returns></returns>
public DataSet getDataTablebySQL(string strSQL, params SqlParameter[] values)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
DataSet ds = new DataSet();
cmd.Parameters.AddRange(values);
SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
myAdapter.Fill(ds);
return ds;
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}

/// <summary>
/// 执行查询SQL语句,返回离线记录集
/// </summary>
/// <param name="strSQL">SQL语句</param>
/// <returns>离线记录DataSet</returns>
public DataTable getDataTablebySQL(string strSQL)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
DataSet ds = new DataSet();
SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
myAdapter.Fill(ds);
return ds.Tables[0];
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}

/// <summary>
/// 执行带参数的查询SQL,返回离线记录集
/// </summary>
/// <param name="strSQL"></param>
/// <returns></returns>
public DataTable getDataTablebySQL(string strSQL,params SqlParameter[] values)
{
using (SqlConnection conn = new SqlConnection(connectionString))
{
using (SqlCommand cmd = new SqlCommand(strSQL, conn))
{
try
{
conn.Open();//打开数据源连接
DataSet ds = new DataSet();
cmd.Parameters.AddRange(values);
SqlDataAdapter myAdapter = new SqlDataAdapter(cmd);
myAdapter.Fill(ds);
return ds.Tables[0];
}
catch (System.Data.SqlClient.SqlException ex)
{
conn.Close();//出异常,关闭数据源连接
throw new Exception(string.Format("执行{0}失败:{1}", strSQL, ex.Message));
}
}
}
}
}
}









































































































































































































































































以上是关于DBhelper的主要内容,如果未能解决你的问题,请参考以下文章