Gra*_*eit 7 c# oracle oracleclient ora-01008
我正在使用System.Data.OracleClient它按名称进行参数绑定,并验证CommandText和Parameters是否同步:
public string CommandText { get; set; }
public IEnumerable<OracleParameter> Parameters { get; set; }
private void VerifyThatAllParametersAreBound()
{
var variableNames = Regex.Matches(CommandText, ":\\w+")
.Cast<Match>().Select(m => m.Value).ToArray();
var parameteterNames = Parameters.Select(p => p.ParameterName).ToArray();
var unboundVariables = variableNames.Except(parameteterNames).ToArray();
if (unboundVariables.Length > 0)
{
throw new Exception("Variable in CommandText missing parameter: "
+ string.Join(", ", unboundVariables) + ".");
}
var unboundParameters = parameteterNames.Except(variableNames).ToArray();
if (unboundParameters.Length > 0)
{
throw new Exception("Parameter that is not used in CommandText: "
+ string.Join(", ", unboundParameters) + ".");
}
}
Run Code Online (Sandbox Code Playgroud)
还有一个查询抛出ORA-01008: not all variables bound.当手动将参数值插入有问题的CommandText时,查询运行,因此CommandText和Parameters-values应该没问题.我正在使用:作为变量和参数名称的前缀,它适用于其他查询.
如何查明此异常的原因?
错误是没有为null值指定DBNull.Value.所以
new OracleParameter(":Foo", item.Foo)
Run Code Online (Sandbox Code Playgroud)
不得不预先放置
item.Foo == null
? new OracleParameter(":Foo", DBNull.Value)
: new OracleParameter(":Foo", item.Foo)
Run Code Online (Sandbox Code Playgroud)
我认为它早期使用ODT.NET而没有空检查,但还没有确认.显然System.Data.OracleClient是使用null值删除参数.