为ASP.NET封装的SQL数据库访问类

简介:

usingSystem;
usingSystem.Configuration;
usingSystem.Data;
usingSystem.Data.SqlClient;
usingSystem.Collections;

namespaceMyCorporation.DepartMent.DataBase
{
///<summary>
///通用数据库类
///</summary>
publicclassDataBase
{

privatestringConnStr=null;

publicDataBase()
{
ConnStr=ConfigurationSettings.AppSettings["ConnStr"];
}
publicDataBase(stringStr)
{
try
{
this.ConnStr=Str;

}
catch(Exceptionex)
{
throwex;
}
}

///<summary>
///返回connection对象
///</summary>
///<returns></returns>
publicSqlConnectionReturnConn()
{
SqlConnectionConn=newSqlConnection(ConnStr);
Conn.Open();
returnConn;
}
publicvoidDispose(SqlConnectionConn)
{
if(Conn!=null)
{
Conn.Close();
Conn.Dispose();
}
GC.Collect();
}
///<summary>
///运行SQL语句
///</summary>
///<paramname="SQL"></param>
publicvoidRunProc(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlCommandCmd;
Cmd=CreateCmd(SQL,Conn);
try
{
Cmd.ExecuteNonQuery();
}
catch
{
thrownewException(SQL);
}
Dispose(Conn);
return;
}

///<summary>
///运行SQL语句返回DataReader
///</summary>
///<paramname="SQL"></param>
///<returns>SqlDataReader对象.</returns>
publicSqlDataReaderRunProcGetReader(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlCommandCmd;
Cmd=CreateCmd(SQL,Conn);
SqlDataReaderDr;
try
{
Dr=Cmd.ExecuteReader(CommandBehavior.Default);
}
catch
{
thrownewException(SQL);
}
//Dispose(Conn);
returnDr;
}

///<summary>
///生成Command对象
///</summary>
///<paramname="SQL"></param>
///<paramname="Conn"></param>
///<returns></returns>
publicSqlCommandCreateCmd(stringSQL,SqlConnectionConn)
{
SqlCommandCmd;
Cmd=newSqlCommand(SQL,Conn);
returnCmd;
}

///<summary>
///生成Command对象
///</summary>
///<paramname="SQL"></param>
///<returns></returns>
publicSqlCommandCreateCmd(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlCommandCmd;
Cmd=newSqlCommand(SQL,Conn);
returnCmd;
}

///<summary>
///返回adapter对象
///</summary>
///<paramname="SQL"></param>
///<paramname="Conn"></param>
///<returns></returns>
publicSqlDataAdapterCreateDa(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlDataAdapterDa;
Da=newSqlDataAdapter(SQL,Conn);
returnDa;
}

///<summary>
///运行SQL语句,返回DataSet对象
///</summary>
///<paramname="procName">SQL语句</param>
///<paramname="prams">DataSet对象</param>
publicDataSetRunProc(stringSQL,DataSetDs)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlDataAdapterDa;
//Da=CreateDa(SQL,Conn);
Da=newSqlDataAdapter(SQL,Conn);
try
{
Da.Fill(Ds);
}
catch(ExceptionErr)
{
throwErr;
}
Dispose(Conn);
returnDs;
}

///<summary>
///运行SQL语句,返回DataSet对象
///</summary>
///<paramname="procName">SQL语句</param>
///<paramname="prams">DataSet对象</param>
///<paramname="dataReader">表名</param>
publicDataSetRunProc(stringSQL,DataSetDs,stringtablename)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlDataAdapterDa;
Da=CreateDa(SQL);
try
{
Da.Fill(Ds,tablename);
}
catch(ExceptionEx)
{
throwEx;
}
Dispose(Conn);
returnDs;
}

///<summary>
///运行SQL语句,返回DataSet对象
///</summary>
///<paramname="procName">SQL语句</param>
///<paramname="prams">DataSet对象</param>
///<paramname="dataReader">表名</param>
publicDataSetRunProc(stringSQL,DataSetDs,intStartIndex,intPageSize,stringtablename)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlDataAdapterDa;
Da=CreateDa(SQL);
try
{
Da.Fill(Ds,StartIndex,PageSize,tablename);
}
catch(ExceptionEx)
{
throwEx;
}
Dispose(Conn);
returnDs;
}

///<summary>
///检验是否存在数据
///</summary>
///<returns></returns>
publicboolExistDate(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlDataReaderDr;
Dr=CreateCmd(SQL,Conn).ExecuteReader();
if(Dr.Read())
{
Dispose(Conn);
returntrue;
}
else
{
Dispose(Conn);
returnfalse;
}
}

///<summary>
///返回SQL语句执行结果的第一行第一列
///</summary>
///<returns>字符串</returns>
publicstringReturnValue(stringSQL)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
stringresult;
SqlDataReaderDr;
try
{
Dr=CreateCmd(SQL,Conn).ExecuteReader();
if(Dr.Read())
{
result=Dr[0].ToString();
Dr.Close();
}
else
{
result="";
Dr.Close();
}
}
catch
{
thrownewException(SQL);
}
Dispose(Conn);
returnresult;
}

///<summary>
///返回SQL语句第一列,第ColumnI列,
///</summary>
///<returns>字符串</returns>
publicstringReturnValue(stringSQL,intColumnI)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
stringresult;
SqlDataReaderDr;
try
{
Dr=CreateCmd(SQL,Conn).ExecuteReader();
}
catch
{
thrownewException(SQL);
}
if(Dr.Read())
{
result=Dr[ColumnI].ToString();
}
else
{
result="";
}
Dr.Close();
Dispose(Conn);
returnresult;
}

///<summary>
///生成一个存储过程使用的sqlcommand.
///</summary>
///<paramname="procName">存储过程名.</param>
///<paramname="prams">存储过程入参数组.</param>
///<returns>sqlcommand对象.</returns>
publicSqlCommandCreateCmd(stringprocName,SqlParameter[]prams)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlCommandCmd=newSqlCommand(procName,Conn);
Cmd.CommandType=CommandType.StoredProcedure;
if(prams!=null)
{
foreach(SqlParameterparameterinprams)
{
if(parameter!=null)
{
Cmd.Parameters.Add(parameter);
}
}
}
returnCmd;
}

///<summary>
///为存储过程生成一个SqlCommand对象
///</summary>
///<paramname="procName">存储过程名</param>
///<paramname="prams">存储过程参数</param>
///<returns>SqlCommand对象</returns>
privateSqlCommandCreateCmd(stringprocName,SqlParameter[]prams,SqlDataReaderDr)
{
SqlConnectionConn;
Conn=newSqlConnection(ConnStr);
Conn.Open();
SqlCommandCmd=newSqlCommand(procName,Conn);
Cmd.CommandType=CommandType.StoredProcedure;
if(prams!=null)
{
foreach(SqlParameterparameterinprams)
Cmd.Parameters.Add(parameter);
}
Cmd.Parameters.Add(
newSqlParameter("ReturnValue",SqlDbType.Int,4,
ParameterDirection.ReturnValue,false,0,0,
string.Empty,DataRowVersion.Default,null));

returnCmd;
}

///<summary>
///运行存储过程,返回.
///</summary>
///<paramname="procName">存储过程名</param>
///<paramname="prams">存储过程参数</param>
///<paramname="dataReader">SqlDataReader对象</param>
publicvoidRunProc(stringprocName,SqlParameter[]prams,SqlDataReaderDr)
{

SqlCommandCmd=CreateCmd(procName,prams,Dr);
Dr=Cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
return;
}

///<summary>
///运行存储过程,返回.
///</summary>
///<paramname="procName">存储过程名</param>
///<paramname="prams">存储过程参数</param>
publicstringRunProc(stringprocName,SqlParameter[]prams)
{
SqlDataReaderDr;
SqlCommandCmd=CreateCmd(procName,prams);
Dr=Cmd.ExecuteReader(System.Data.CommandBehavior.CloseConnection);
if(Dr.Read())
{
returnDr.GetValue(0).ToString();
}
else
{
return"";
}
}

///<summary>
///运行存储过程,返回dataset.
///</summary>
///<paramname="procName">存储过程名.</param>
///<paramname="prams">存储过程入参数组.</param>
///<returns>dataset对象.</returns>
publicDataSetRunProc(stringprocName,SqlParameter[]prams,DataSetDs)
{
SqlCommandCmd=CreateCmd(procName,prams);
SqlDataAdapterDa=newSqlDataAdapter(Cmd);
try
{
Da.Fill(Ds);
}
catch(ExceptionEx)
{
throwEx;
}
returnDs;
}

}
}

目录
相关文章
|
9月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1454 152
|
9月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
1065 156
|
9月前
|
SQL 人工智能 Linux
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
726 5
SQL Server 2025 RC1 发布 - 从本地到云端的 AI 就绪企业数据库
|
8月前
|
SQL 存储 监控
SQL日志优化策略:提升数据库日志记录效率
通过以上方法结合起来运行调整方案, 可以显著地提升SQL环境下面向各种搜索引擎服务平台所需要满足标准条件下之数据库登记作业流程综合表现; 同时还能确保系统稳健运行并满越用户体验预期目标.
414 6
|
9月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
882 0
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
722 5
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
444 7
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
376 0
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
373 0