gpt4 book ai didi

c# - 从 LINQ ExecuteMethodCall 中提取 SQL 'print' 消息

转载 作者:太空狗 更新时间:2023-10-30 01:20:29 25 4
gpt4 key购买 nike

我以相当简单的方式通过 LINQ 调用存储过程:

    [Function(Name = "dbo.add_second_override")]
public int AddSecondOverride(
[Parameter(DbType = "numeric(10)")] decimal account_id,
[Parameter(DbType = "numeric(10)")] decimal security_id,
[Parameter(DbType = "varchar(255)")] string reason,
[Parameter(DbType = "numeric(10)")] decimal? order_id,
[Parameter(DbType = "numeric(10)")] decimal current_user)
{
IExecuteResult result = this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), new object[] { account_id, security_id, reason, order_id, current_user });

if ((int)result.ReturnValue != 0)
{
string errorDescription = Sysmessages.FirstOrDefault(x => x.Error == (int)result.ReturnValue).Description;
throw new Exception(errorDescription);
}

return (int)result.ReturnValue;
}

这工作正常,但如果存储过程中有 SQL 打印语句,我该如何提取此信息?例如

create procedure dbo.add_second_override
(
@account_id numeric(10),
@security_id numeric(10),
@reason varchar(255) = null output,
@order_id numeric(10) = null,
@current_user numeric(10)
)
as
begin
/* Do some other stuff */
print 'This is a SQL message'
return 0
end

曾经有一种方法可以使用 SQLClient 检索此消息,但我找不到与 LINQ 相关的任何内容。

请注意,我无法在存储过程中抛出异常而不是使用“打印”。它必须以某种方式获取打印语句。

最佳答案

我没有找到任何特定于 Linq 的内容。但是从这个问题中排队

Capture Stored Procedure print output in .NET (Different model!)

如果您可以连接到 SqlConnection,您就可以对 InfoMessage 事件作出 react 。

如果您正在使用 Entity Framework 和 DbContext - 您可以这样做。

SqlConnection conn = (SqlConnection)context.Database.Connection;
conn.Open();
conn.InfoMessage += (s, e) => Console.WriteLine(e.Message);

正如我所说,我意识到这不是特定于 Linq 的方法 - 但至少您可以通过这样的方法实现您的最终目标。

关于c# - 从 LINQ ExecuteMethodCall 中提取 SQL 'print' 消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18914916/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com