c# – ORA-01008绑定了所有变量
发布时间:2020-12-15 08:35:18 所属栏目:百科 来源:网络整理
导读:我正在使用System.Data.OracleClient,它按名称进行参数绑定,并验证CommandText和Parameters是否同步: public string CommandText { get; set; } public IEnumerableOracleParameter Parameters { get; set; } private void VerifyThatAllParametersAreBound
我正在使用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) + "."); } } 还有一个查询抛出ORA-01008:并非所有变量都绑定.当手动将参数值插入有问题的CommandText时,查询运行,因此CommandText和Parameters-values应该没问题.我正在使用:作为变量和参数名称的前缀,它适用于其他查询. 如何查明此异常的原因? 解决方法
错误是没有为null值指定DBNull.Value.所以
new OracleParameter(":Foo",item.Foo) 不得不预先放置 item.Foo == null ? new OracleParameter(":Foo",DBNull.Value) : new OracleParameter(":Foo",item.Foo) 我认为它早期使用ODT.NET而没有空检查,但还没有确认.显然,System.Data.OracleClient正在删除带有null值的参数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读