我正在使用 ODP.NET 在远程 Oracle DB 和本地 Oracle XE DB 之间编写某种同步机制。我正在同步的表有一个空间列(因此是一个用户定义的类型,sdo_geometry)。我在 C# 中的逻辑在远程数据库上进行选择,遍历 OracleDataReader 的结果并将结果插入本地数据库。
这就像一个魅力,但是当空间列的值为 DBNull.Value 时,插入失败并显示以下消息:
Object reference not set to an instance of an object.
at Oracle.DataAccess.Client.OracleParameter.PostBind_OracleObject(OracleConnection conn)
at Oracle.DataAccess.Client.OracleParameter.PostBind(OracleConnection conn, OpoSqlValCtx* pOpoSqlValCtx, Int32 arraySize)
at Oracle.DataAccess.Client.OracleCommand.ExecuteNonQuery()
at Gwr.Bsb.Oli.Framework.Helpers.SynchronizationHelper.TryModifyData(OracleCommand cmd)
代码看起来像:
var parameter = new OracleParameter(parameterName, OracleDbType.Object);
parameter.OracleDbType = OracleDbType.Object;
parameter.UdtTypeName = "MDSYS.SDO_GEOMETRY";
parameter.Direction = ParameterDirection.InputOutput;
parameter.Value = reader[i];
正如我之前所说。当有空间值时,代码效果很好。但是当reader[i]的值为 DBNull.Value 时,它会失败...
有任何想法吗?