- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用一个 DAL 对象,该对象的布局类似于以下代码。我简化了很多代码代码只是为了显示设置。
public class UserDatabase : IDisposable
{
private SqlDataAdapter UserDbAdapter;
private SqlCommand UserSelectCommand;
private SqlCommand UserInsertCommand;
private SqlCommand UserUpdateCommand;
private SqlCommand UserDeleteCommand;
private System.Data.SqlClient.SqlConnection SQLConnection;
public UserDatabase()
{
this.SQLConnection = new System.Data.SqlClient.SqlConnection(ConnectionString);
this.UserDbAdapter= new SqlDataAdapter();
this.UserDbAdapter.DeleteCommand = this.UserDeleteCommand;
this.UserDbAdapter.InsertCommand = this.UserInsertCommand;
this.UserDbAdapter.SelectCommand = this.UserSelectCommand;
this.UserDbAdapter.UpdateCommand = this.UserUpdateCommand;
}
private bool FillUsers(DataSet UserDataSet, out int numberOfRecords)
{
bool success = true;
numberOfRecords = 0;
string errorMsg = null;
this.UserDbAdapter.SelectCommand = this.GetUsersSelectCommand();
numberOfRecords = UserDbAdapter.Fill(UserDataSet, UsersTableName);
return success;
}
private SqlCommand GetUserSelectCommand()
{
if (this.UserSelectCommand==null)
this.UserSelectCommand= new System.Data.SqlClient.SqlCommand();
this.UserSelectCommand.CommandText = "dbo.Users_Select";
this.UserSelectCommand.CommandType = System.Data.CommandType.StoredProcedure;
this.UserSelectCommand.Connection = this.SQLConnection;
this.UserSelectCommand.Parameters.Clear();
this.UserSelectCommand.Parameters.AddRange(new System.Data.SqlClient.SqlParameter[] {
new System.Data.SqlClient.SqlParameter("@RETURN_VALUE", System.Data.SqlDbType.Variant, 0, System.Data.ParameterDirection.ReturnValue, false, ((byte)(0)), ((byte)(0)), "", System.Data.DataRowVersion.Current, null)});
return UserSelectCommand;
}
还有多个其他 Fill 类型函数以相同的方式编写,重用了 Connection 对象、SqlCommands 和 SqlDataAdapter。 SqlDataAdapter 在内部管理 SqlConnection 的打开和关闭。
所以我的问题是多部分的。这个设计不好吗?如果是,为什么?
如果不好,是否应该更改为将内容保留在更局部的范围内,如下所示:
public bool FillUsers(DataSet UserDataSet)
{
using (SqlConnection conn = new SqlConnection(ConnectionString))
{
using (SqlCommand command = GetUsersSelectCommand())
{
using (SqlDataAdapter adapter = new SqlDataAdapter(command, conn))
{
adapter.Fill(UserDataSet, UsersTableName);
}
}
}
}
所有功能都必须这样做,这似乎是创建、处理然后重新制作比保留项目更糟糕的事情。然而,这似乎是我在网上随处看到的设置。
最佳答案
不,这没有任何问题。您应该在完成处理后立即释放实现了 IDisposable
的对象。
给定一个 SqlConnection
,当您释放连接时,底层连接将简单地返回到池中。它不一定像您想象的那样“封闭”。最好让连接池完成它的工作。 Here是 MSDN 上指向 ADO.NET 连接池的链接。试图让它做一些它不是为它设计的事情(令人惊讶的是,有些人称之为优化)通常是在兔子洞里的一次旅行。
另外,在尝试优化问题之前,请确保您已实际测量并观察到问题。 (我的意思不是苛刻,只是为了节省您的时间)。
关于c# - 是否应该重用 SqlConnection、SqlDataAdapter 和 SqlCommand 对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11236203/
我正在编写一个程序,从 SQL 数据库中提取数据并将其输入到 Excel 中。我一切正常,只是我注意到在 Excel 中返回的行与在 SQL 中看到的不匹配。填充 DataTable 对象时,最后
我正在尝试更新 TableTwo使用 DataTable使用 TableOne 构建. 表之间的关系是一个名为 TableOneId 的外部列里面 TableTwo . 我使用以下代码示例来完成这项工
看来我的代码不完整或者我的语法有误,但我尽力想出了某种解决方案,但到目前为止没有成功......所以这就是我正在尝试做的事情:我有几个下拉框,想将每个下拉框的选定值分配给表适配器中的值。到目前为止,这
SqlDataAdapter 是否打开自己的连接? private DataTable UpdateOxa(ProductCatalogSyncData syncDataModel,
我正在尝试批量插入/更新 SqlDataAdapter。当我设置 UpdateBatchSize = 1 时,它可以工作,但将其设置为 2 会出现异常“指定的参数名称‘Id’无效。”。 using (
我有两个表,User 和 UserReputation。我想用 SqlDataAdapter 获取数据。 SqlConnection conn = new SqlConnection(
大家好,我有这个 SqlDataAdapter 可以找到最高值: DataTable dt = new DataTable(); SqlDataAdapter SDA = ne
我有一个问题。我整天都在尝试解决它,但我真的被困住了。我正在使用 VS2010 和 SQL Server 2012(相当糟糕的组合),我正在尝试执行一段相当简单的 C# 和 ASP.net 代码,如下
我想使用 SqlDataAdapter 将数据从一个数据库表插入到另一个数据库表,但在从另一个表导入行后没有效果 代码 DataTable table1 = objDataset1.Tables[0]
我想知道 SqlDataAdapter 是如何在内部工作的,尤其是当使用 UpdateCommand 来更新一个巨大的 DataTable 时(因为它通常比仅发送要快得多来自循环的 sql 语句)。
我正在尝试在构建 sqldataadapter 后运行更新语句。我的表中有一个名为 INIT_PHASE 的列,如果 INIT_PHASE 为空或没有数据,那么我想将其设置为 1。我已经尝试过,但我似
我在 MS SQL 2005 中有一个带有主键的表,它有几十万条记录。当我在 Management Studio 中查询它以获取记录时,它带来的速度非常快,但是当我使用下面的代码找到它时,它需要很多秒
假设您调用了 SQlDataAdapter 的更新方法: MyDataSet.Tables[0].DefaultView.RowStateFilter = DataViewRowSta
我知道通常推荐的从存储过程填充 DataSet 实例的方法是使用 SqlDataAdapter.Fill(DataSet)。我能找到的每个答案都说要以开箱即用的方式使用它。我会正常授予的,它很好用。
我正在使用 VS2012 和 SQL Server Express 2008。我已经归结我的连接/查询以尝试找出为什么我的 DataSet 没有被填充。连接成功完成,没有抛出异常,但是适配器没有填充D
我的问题:有没有办法像这样用一个 SqlDataAdapter 运行多个存储过程 adapter = new SqlDataAdapter("ProcforselectUserTableWhere ;
我做了以下事情: SqlConnection conn = new SqlConnection("... my connection string ..."); dataAdapter = new S
所以,我有一个必须维护的内部数据访问框架,并且我要向其中添加事务。我在放入一个包时遇到问题:Transactions、SqlDataAdapters、SqlCommandBuilders 以及主键定义
然而,我一直在尝试将 SQL 数据库加载到 C++ 中的数据表中;它似乎不想工作。不过,随着 DataReader 的工作,连接正在工作。这是我的代码 void importDatabase() {
所以我试图用来自 MSSQL 查询的数据填充 DataTable,但出于某种原因它完全拒绝工作,这让我非常恼火。 当我使用 SqlDataReader 和 Read() 遍历结果时,我得到了结果,甚至
我是一名优秀的程序员,十分优秀!