遇到往ORACLE数据库中插入数据时总是报ORA-01084 invalid argument in OCI call错误,经分析是因为表中的一个字段类型为CLOB,并且可为空,当在给该字段插入空值时引发的该错误。后来判断是否为空值,如果为空值使用DBNull.Value,以此解决了该问题。
Null 指的是无效的对象引用;而 DBNull 是一个类, DBNull.Value 是它唯一的实例 。DBNull 的实例 DBNull.Value是数据库表中的空数据在 .Net 代码中的表现形式。我们知道,当数据库表中的可空字段没有被赋值时,数据库表中的该字段会被指定为 Null ,那么这个 Null 值在 .Net 代码中该如何表示呢,使用的就是 DBNull .Value。反过来说,在代码中,当一个字段的值等于 DBNull .Value,那就说明这个字段在数据库中保存的值为 Null ,也就是说它在数据库中的值为空。所以, DBNull.Value 对象指向有效的对象 ,并不像Null 没有指向任何有效的对象。
DBNull 是一个单独的类,这意味着该类只能存在此实例。
如果数据库字段的数据缺失,则您可以使用 DBNull.Value 属性将 DBNull 对象值显式分配给该字段。然而,大部分数据提供程序会自动进行分配。
若要计算数据库字段以确定其值是否为 DBNull,则可以将字段值传递给 DBNull.Value.Equals 方法。但此方法不常用,因为有许多其他方式可计算数据库字段是否缺少数据。这些方法包括 Visual Basic 的 IsDBNull 函数、Convert.IsDBNull 方法、DataTableReader.IsDBNull 方法、IDataRecord.IsDBNull 方法和其他几种方法。
示例
下面的示例调用 DBNull.Value.Equals 方法,来确定联系人数据库中的数据库字段是否具有有效值。如果具有有效值,字段值将被追加到在标签中输出的字符串中。
private void OutputLabels(DataTable dt) { string label; // Iterate rows of table foreach (DataRow row in dt.Rows) { int labelLen; label = String.Empty; label += AddFieldValue(label, row, "Title"); label += AddFieldValue(label, row, "FirstName"); label += AddFieldValue(label, row, "MiddleInitial"); label += AddFieldValue(label, row, "LastName"); label += AddFieldValue(label, row, "Suffix"); label += "\n"; label += AddFieldValue(label, row, "Address1"); label += AddFieldValue(label, row, "AptNo"); label += "\n"; labelLen = label.Length; label += AddFieldValue(label, row, "Address2"); if (label.Length != labelLen) label += "\n"; label += AddFieldValue(label, row, "City"); label += AddFieldValue(label, row, "State"); label += AddFieldValue(label, row, "Zip"); Console.WriteLine(label); Console.WriteLine(); } } private string AddFieldValue(string label, DataRow row, string fieldName) { if (! DBNull.Value.Equals(row[fieldName])) return (string) row[fieldName] + " "; else return String.Empty; }