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

}
}

目录
相关文章
|
7天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
47 10
|
7天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
64 6
|
3天前
|
SQL 缓存 Java
Java数据库连接池:优化数据库访问性能
【4月更文挑战第16天】本文探讨了Java数据库连接池的重要性和优势,它能减少延迟、提高效率并增强系统的可伸缩性和稳定性。通过选择如Apache DBCP、C3P0或HikariCP等连接池技术,并进行正确配置和集成,开发者可以优化数据库访问性能。此外,批处理、缓存、索引优化和SQL调整也是提升性能的有效手段。掌握数据库连接池的使用是优化Java企业级应用的关键。
|
4天前
|
SQL 数据库
数据库SQL语言实战(二)
数据库SQL语言实战(二)
|
4天前
|
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进行限制。
30 3
|
7天前
|
SQL 监控 数据库
数据库管理与电脑监控软件:SQL代码优化与实践
本文探讨了如何优化数据库管理和使用电脑监控软件以提升效率。通过SQL代码优化,如使用索引和调整查询语句,能有效提高数据库性能。同时,合理设计数据库结构,如数据表划分和规范化,也能增强管理效率。此外,利用Python脚本自动化收集系统性能数据,并实时提交至网站,可实现对电脑监控的实时性和有效性。这些方法能提升信息系统稳定性和可靠性,满足用户需求。
29 0
|
15天前
|
SQL 数据可视化 关系型数据库
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)
轻松入门MySQL:深入探究MySQL的ER模型,数据库设计的利器与挑战(22)
|
15天前
|
存储 关系型数据库 MySQL
轻松入门MySQL:数据库设计之范式规范,优化企业管理系统效率(21)
轻松入门MySQL:数据库设计之范式规范,优化企业管理系统效率(21)
|
15天前
|
关系型数据库 MySQL 数据库
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
轻松入门MySQL:精准查询,巧用WHERE与HAVING,数据库查询如虎添翼(7)
|
17天前
|
存储 关系型数据库 MySQL
数据库字符编码MySQL中使用UTF-8还是UTFB4
数据库字符编码MySQL中使用UTF-8还是UTFB4
20 0