我是第一次尝试从C#访问Oracle。我发现Oracle不喜欢VarChar
参数的值为null
(C#)。我希望会有一些隐含的转换,但我很欣赏它的区别。
所以我需要捕获这些空值并确实提供DBNull.Value
吗?最明显的方法是使用合并运算符??
:
param myParm = myObject.MyProperty ?? DBNull.Value;
除非它不接受System.DBNull
的值...所以我必须使用:
param myParm = myObject.MyProperty ?? DBNull.Value.ToString();
......这肯定与:
相同param myParm = myObject.MyProperty ?? String.Empty;
..这也有效。
但我总是明白,根据ANSI SQL规则,空字符串(“”)!= NULL值......但它似乎在Oracle中。
无论如何,我的问题是,处理空字符串值的情况的最佳,实用或理论方法是什么?有没有一个我没有发现的光滑替代品?或者这只是我们接受的另一个Oracle特质?
答案 0 :(得分:3)
空字符串(“”)如果事实上不等于NULL值,那是因为NULL不等于任何东西(甚至不是另一个NULL)(这就是为什么你在SQL中说IS NULL
的原因声明而不是= NULL
。
NULL表示“无值”,空字符串没有值,因此Oracles设计者认为空字符串与NULL之间没有区别。
param myParm = myObject.MyProperty ?? DBNull.Value;
失败,因为??
的两边必须是同一类型。 MyProperty
我假设是一个字符串,而DBNull.Value
是一个DBNull
对象。
答案 1 :(得分:1)
此处有一个更简单的解决方案,因为??
无法正常工作,而String.Empty
将不适用于您的空值。
param myParm;
if (myObject.MyProperty == null)
{
myParm = DBNull.Value;
}
else
{
myParm = myObject.MyProperty;
}
它可能不像null-coalescer那样'光滑',但它应该有效。
答案 2 :(得分:1)
如果将值设置为null
,.NET将不会在生成的SQL中指定参数。因此,一个选项是为Oracle中的参数指定默认值NULL
。这意味着将值设置为null
或DBNull.Value
具有相同的效果。一个没有传递任何值,并且假定NULL
,而另一个显式传递值NULL
。
显然,假设您可以修改数据库,并且您不需要为该参数设置不同的默认值。