- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
当使用如下所示的 using() {}
(sic) block 时,并假设 cmd1
没有超出第一个 using 的范围() {}
block ,为什么第二个 block 要抛出消息异常
The SqlParameter is already contained by another SqlParameterCollection
这是否意味着附加到 cmd1
的资源和/或句柄 - 包括参数 (SqlParameterCollection
) 在 block 末尾被销毁时不会被释放?
using (var conn = new SqlConnection("Data Source=.;Initial Catalog=Test;Integrated Security=True"))
{
var parameters = new SqlParameter[] { new SqlParameter("@ProductId", SqlDbType.Int ) };
using(var cmd1 = new SqlCommand("SELECT ProductName FROM Products WHERE ProductId = @ProductId"))
{
foreach (var parameter in parameters)
{
cmd1.Parameters.Add(parameter);
}
// cmd1.Parameters.Clear(); // uncomment to save your skin!
}
using (var cmd2 = new SqlCommand("SELECT Review FROM ProductReviews WHERE ProductId = @ProductId"))
{
foreach (var parameter in parameters)
{
cmd2.Parameters.Add(parameter);
}
}
}
注意:在第一个 using() {} block 的最后一个大括号之前执行 cmd1.Parameters.Clear() 将使您免于异常(并且可能尴尬)。
如果你需要复制你可以使用下面的脚本来创建对象:
CREATE TABLE Products
(
ProductId int IDENTITY(1,1) NOT NULL PRIMARY KEY CLUSTERED,
ProductName nvarchar(32) NOT NULL
)
GO
CREATE TABLE ProductReviews
(
ReviewId int IDENTITY(1,1) NOT NULL PRIMARY KEY CLUSTERED,
ProductId int NOT NULL,
Review nvarchar(128) NOT NULL
)
GO
最佳答案
我怀疑 SqlParameter
“知道”它是哪个命令的一部分,并且当命令被释放时该信息不会被清除,但是当您调用时会被清除command.Parameters.Clear()
。
我个人认为我首先会避免重用这些对象,但这取决于您:)
关于c# - SqlParameter 已包含在另一个 SqlParameterCollection 中 - 是否使用(){}作弊?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7837762/
我正在尝试使用这些命名空间之一 //using Microsoft.Data.SqlClient; using System.Data.SqlClient; 我的模型 public class Get
我将我的项目从 ASP.NET Core 2.2 迁移到 ASP.NET Core 3.0。现在我得到了这个异常(exception)。在 ASP.NET Core 2.2 中,它使用 FromSql
我想知道如何SqlParameter知道没有指定的类型吗? 例如,在实例化参数对象时,您不需要指定 DB 类型。以某种方式执行命令时,.net 会为您处理此问题。在幕后是否有某种转换正在发生?当你做/
我们有一个代码块,它创建一个 sqlParameters 列表,然后将它们传递给存储过程。要求根据输入文本框是否为空有条件地使一些值无效。 基本代码: var SqlParams = new List
如何设置SqlParameter的值相当于 SQL INSERT 语句的 DEFAULT 关键字? MSDN documentation表示“使用 null 或不设置 Value 以使用参数的默认值。
如何设置SqlParameter的值相当于 SQL INSERT 语句的 DEFAULT 关键字? MSDN documentation表示“使用 null 或不设置 Value 以使用参数的默认值。
我想从我的代码中删除手动转义。而不是这个,我想使用 SqlParameter 对象。 foreach (ThreadPost post in ThreadPosts) { string ne
Sql命令构建 我已经构建了如下的 Sql 命令: string _InsertVehicleQuery = "INSERT INTO VSI_VehicleRecords(StockNumb
SqlParameter[] _parameters = { new SqlParameter( "@IDNumber", Person.IDNumber ),
给定以下代码行: cmd.Parameters.Add(new SqlParameter("@displayId", SqlDbType.NVarChar).Value = customer.Disp
我正在尝试访问一个存储过程,但我收到一条错误消息: Procedure or function 'getbug' expects parameter '@bugID', which was not s
我需要检查 SqlParameter 对象的值并根据特殊标签更改它。即:[BB] ==> 棒球,[FP] ==> 快投。 我可以用这样的附加函数来做到这一点: _params.Add(new SqlP
我正在尝试转换: command.Parameters.Add (new SqliteParameter (DbType.Int32) { Value = id }); 到一个普通的 SqlParam
我有一个网络服务,所以处理程序一直被同时调用多次。 我在里面创建了 SqlConnection 和 SqlCommand。我必须执行大约 7 个不同的命令。不同的命令需要不同的参数,所以我只添加一次:
我收到这个错误: System.Data.SqlClient.SqlException: 'The parameterized query '(@inputKarakterSoort varchar(
我有一个 SqlCommand我想打电话Prepare()在谁的CommandType = Text (它 不能 是一个存储过程)。 为了做到这一点,我需要设置 Size参数上的属性非零,否则抛出异常
这个问题已经有答案了: SQL Server error "Procedure expects parameter" (1 个回答) 已关闭 8 年前。 我正在尝试从 C# 程序访问存储过程,令人难以
我正在使用最新版本的 MiniProfiler,一切都已按我的预期设置和工作。我唯一的问题是 SqlParameters 没有显示。 例如,我正在运行一个存储过程:- var cmd = dbcon.
我有一个 SqlCommand,它运行一个包含两个整数输出参数的存储过程。就在 SqlCommand 运行之前,我可以看到输出参数设置为正确的值,但是当命令实际执行时,它对参数 1 使用 NULL,对
我正在开发一个必须支持多种语言的应用程序。为了解决特殊字符问题,我在文本字段中使用了 NVarhcar。所以我对文本字段的 SQL 查询是 insert into tbl_text(text)valu
我是一名优秀的程序员,十分优秀!