Oracle无效字符和长原始数据

时间:2010-03-03 12:28:35

标签: c# oracle long-integer

我是Oracle世界的新手,我正在尝试使用参数化查询从.NET(C#)进行插入。

我的表是:

CREATE TABLE layer_mapping
(
    lm_id NUMBER NOT NULL,
    lm_layer_name VARCHAR2(50) NOT NULL,
    lm_layer_file LONG RAW NOT NULL,
    CONSTRAINT lm_pk PRIMARY KEY(lm_id)
)

“INSERT INTO layer_mapping VALUES(:lm_id,:lm_layer_name,:lm_layer_file);”

在Visual Studio中,上面的查询是在运行时生成的,我有BindByName = true;

我怀疑错误的“lm_layer_file”值正从文件传送到一个类,它是一个字节数组。以下是该课程的一个例子。

public class LayerMapping()
{
    private Int32 _id;
    private String _name;
    private Byte[] _file;
}

奇怪的是,使用PostgreSQL,一切都会正常发生而没有错误。

我使用错误的方法来生成我的长原始值吗?

哦,我收到的错误是ORA-0991(无效的字符)。

有什么想法吗?

2 个答案:

答案 0 :(得分:4)

想出来:

我的sql命令构建器添加了';'在命令的最后,但似乎OracleCommand类也这样做。

解决。

答案 1 :(得分:0)

我会说你应该做的第一件事就是在表格中使用CLOB,假设你是9i或更高,而不是LONG RAW。 LONG / LONG RAWs已经淘汰了很长时间 - 这是甲骨文仍然保留它们的唯一原因是因为它们存在于数据字典中,Oracle承诺永远不会改变它。