0

我正在使用 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 时,它​​会失败...

有任何想法吗?

4

1 回答 1

0

有趣的东西......我看错了方向。

问题不在于插入,而是在执行插入时出现。问题与参数方向有关。似乎代码无法处理参数的输出方向。当我改变它时,一切又开始工作了。

所以问题暂时解决了。

于 2012-08-15T13:33:50.107 回答