- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在对现有的 SQL Server 数据库使用 OrmLite,该数据库已发布用于访问的存储过程。这些 SP 之一采用 3 个 int 参数,但期望其中一个或另一个为空。但是,没有任何参数被声明为可选。
这是我试过的代码:
using (IDbConnection scon = myFactory.OpenDbConnection())
{
rowCount = scon.SqlScalar<int>("EXEC myProc @FileID, @FileTypeID, @POID",
new
{
FileID = req.FileId,
FileTypeID = (int?)null,
POID = req.PoId,
});
}
但这会产生一个 SqlException:必须声明标量变量“@FileTypeID”。检查底层的 SQLParameterCollection 表明 OrmLite 只生成了两个参数。
是否可以使用空参数调用此 SP?
最佳答案
SqlScalar 不支持它。当您查看代码时,您会看到类 ServiceStack.OrmLite.OrmLiteReadExtensions 中的 SqlScalar 方法执行 SetParameters 方法,该方法负责将参数添加到查询中,第二个参数(excludeNulls)等于 true 我不知道为什么 - mythz 应该回答这个问题; ).
如果你想修复它,那么你已经更改了所有 SqlScalar 方法以使用 true 调用 SetParameters 并且 SetParameters 方法应该如下所示(必须支持 DBNull.Value not null)
private static void SetParameters(this IDbCommand dbCmd, object anonType, bool excludeNulls)
{
dbCmd.Parameters.Clear();
lastQueryType = null;
if (anonType == null) return;
var pis = anonType.GetType().GetSerializableProperties();
foreach (var pi in pis)
{
var mi = pi.GetGetMethod();
if (mi == null) continue;
var value = mi.Invoke(anonType, new object[0]);
if (excludeNulls && value == null) continue;
var p = dbCmd.CreateParameter();
p.ParameterName = pi.Name;
p.DbType = OrmLiteConfig.DialectProvider.GetColumnDbType(pi.PropertyType);
p.Direction = ParameterDirection.Input;
p.Value = value ?? DBNull.Value; // I HAVE CHANGED THAT LINE ONLY
dbCmd.Parameters.Add(p);
}
}
当您更改代码时,您可以通过以下方式为参数设置 null:
var result = db.SqlScalar<int>("EXEC DummyScalar @Times", new { Times = (int?)null });
在我看来,您可以在 github 上将其描述为缺陷,我可以提出拉取请求。
关于ormlite-servicestack - 如何使用 OrmLite 将非可选 NULL 参数传递给存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17432909/
我正在尝试用 Swift 编写这段 JavaScript 代码:k_combinations 到目前为止,我在 Swift 中有这个: import Foundation import Cocoa e
我是一名优秀的程序员,十分优秀!