繁体   English   中英

C#/ Oracle10g = null vs DBNull.Value vs String.Empty

[英]C#/Oracle10g = null vs DBNull.Value vs String.Empty

我正在首次尝试从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的另一个特质?

空字符串(“”)如果事实上不等于NULL值,那是因为NULL不等于任何东西(甚至不是另一个NULL)(这就是为什么你在SQL语句中说IS NULL而不是= NULL

NULL表示“无值”,空字符串没有值,因此Oracles设计者认为空字符串和NULL之间没有区别。

param myParm = myObject.MyProperty ?? DBNull.Value; 失败,因为两侧?? 必须是同一类型。 MyProperty我假设是一个字符串,而DBNull.Value是一个DBNull对象。

这里有一个更简单的解决方案,因为?? 将无法正常工作, String.Empty将无法用于您的null值。

param myParm;

if (myObject.MyProperty == null)
{
   myParm  = DBNull.Value;
}
else 
{
   myParm = myObject.MyProperty;
}

它可能不像null-coalescer那样'光滑',但它应该有效。

如果将该值设置为null ,则.NET将不会在生成的SQL中指定该参数。 因此,一个选项是为Oracle中的参数指定默认值NULL 这意味着将值设置为nullDBNull.Value具有相同的效果。 一个没有传递值,将假定为NULL ,而另一个显式传递NULL

显然,假设您可以修改数据库,并且您还不需要为该参数设置不同的默认值。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM