为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;
}

}
}

目录
相关文章
|
12天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
51 10
|
12天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
74 6
|
8天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
8天前
|
SQL 关系型数据库 数据库
【后端面经】【数据库与MySQL】SQL优化:如何发现SQL中的问题?
【4月更文挑战第12天】数据库优化涉及硬件升级、操作系统调整、服务器/引擎优化和SQL优化。SQL优化目标是减少磁盘IO和内存/CPU消耗。`EXPLAIN`命令用于检查SQL执行计划,关注`type`、`possible_keys`、`key`、`rows`和`filtered`字段。设计索引时考虑外键、频繁出现在`where`、`order by`和关联查询中的列,以及区分度高的列。大数据表改结构需谨慎,可能需要停机、低峰期变更或新建表。面试中应准备SQL优化案例,如覆盖索引、优化`order by`、`count`和索引提示。优化分页查询时避免大偏移量,可利用上一批的最大ID进行限制。
33 3
|
11天前
|
SQL 监控 数据库
数据库管理与电脑监控软件:SQL代码优化与实践
本文探讨了如何优化数据库管理和使用电脑监控软件以提升效率。通过SQL代码优化,如使用索引和调整查询语句,能有效提高数据库性能。同时,合理设计数据库结构,如数据表划分和规范化,也能增强管理效率。此外,利用Python脚本自动化收集系统性能数据,并实时提交至网站,可实现对电脑监控的实时性和有效性。这些方法能提升信息系统稳定性和可靠性,满足用户需求。
41 0
|
12天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
20天前
|
数据库 SQL 索引
什么是数据库 SQL Execution Plan
什么是数据库 SQL Execution Plan
11 0
|
SQL 安全 .NET
ASP.NET SQL 注入免费解决方案
任何一种使用数据库web程序(当然,也包括桌面程序)都有被SQL注入的风险。防止被SQL注入,最基本的方法是在代码级别就要阻止这种可能,这个网上讲的很多,我就不多说了。不过如果你拿到的是一个已经完工的产品,这个时候该如何解决呢?我介绍几种对于ASP和ASP.NET有效的防止SQL注入的方案,而且是免费的。
|
3月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
41 0
|
1月前
|
开发框架 前端开发 .NET
进入ASP .net mvc的世界
进入ASP .net mvc的世界
29 0

热门文章

最新文章