首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle无效字符和较长的原始字符

Oracle无效字符和较长的原始字符
EN

Stack Overflow用户
提问于 2010-03-03 20:28:35
回答 2查看 809关注 0票数 0

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

我的表格是:

代码语言:javascript
复制
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“值是从一个文件提供给一个类的,它是一个字节数组。下面是这个类的一个例子。

代码语言:javascript
复制
public class LayerMapping()
{
    private Int32 _id;
    private String _name;
    private Byte[] _file;
}

奇怪的是,在PostgreSQL中,一切都是正常的,没有错误。

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

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

有什么想法吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-03-03 22:40:52

弄清楚了:

我的sql命令构建器在命令的末尾添加了一个';‘,但似乎OracleCommand类也是这样做的。

解决了。

票数 4
EN

Stack Overflow用户

发布于 2010-03-03 22:30:43

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2371168

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档