简单描述Oracle Clob类型

数据库 Oracle
这里介绍Oracle Clob类型处理解析最近利用NHibernate映射类型为Clob字段在插入数据时发现当字符的字节数在 2000-4000之间时报错。

Oracle还是比较常用的,于是我研究了一下Oracle Clob类型,在这里拿出来和大家分享一下,希望对大家有用。Oracle Clob类型处理解析最近利用NHibernate映射类型为Clob字段在插入数据时发现当字符的字节数(一个半角字符一个字节,一个全角字符两个字节)在 2000-4000之间时报错(ORA-01461:仅可以插入LONG列的LONG值赋值)。Oracle Clob类型方式1:直接将CLOB的值拼写在SQL语句中。代码:

  1. string id = Guid.NewGuid().ToString();  
  2. OracleCommand cmd = Conn.CreateCommand();  
  3. cmd.CommandText = "insert into xx(id,test) values('" + id + "','" + data + "')";  
  4. // data是一个变量,存储你要插入的字符串  
  5. cmd.ExecuteNonQuery(); 

情况分析:当data的长度大于4000时报错(ORA-01704:文字字符串过长),小于或等于4000时正常插入。

原因分析:之所以会出现长度大于4000时报错,是因为Oracle中有SQL语句中两个单引号之间的字符数不能大于4000的限制。'" + data + "' data在sql语句之间,当data的值大于4000个字节时就会报错。

解决办法:这种方式比较棘手,但有更好的方式,下边会讲到 。

Oracle Clob类型方式2:采用参数形式。代码:

  1. string id = Guid.NewGuid().ToString();  
  2. OracleCommand cmd = Conn.CreateCommand();  
  3. cmd.CommandText = "insert into xx(id,test) values('" + id + "','" + data + "')";  
  4. // data是一个变量,存储你要插入的字符串  
  5. cmd.ExecuteNonQuery(); 

情况分析:采用这种方式能够正常插入。所以推荐用这种方式。

原因分析:无

解决办法:无

【编辑推荐】

  1. Oracle监听器,让你监听想要的东东
  2. 你是否懂得Oracle.Net协议栈
  3. 概论Oracle数据库优化器
  4. 简明扼要介绍Oracle Provider
  5. 详谈捕获Oracle SQL语句执行计划
责任编辑:佚名 来源: 博客园
相关推荐

2009-11-09 17:27:38

Oracle编码SQL

2017-09-05 09:18:54

OracleCLOB大数据

2009-11-17 16:47:09

Oracle物化视图日

2009-09-03 16:55:58

C#引用类型

2009-09-25 14:04:12

Hibernate读取

2010-04-23 16:18:36

Oracle存取

2010-03-30 13:49:15

Oracle clob

2010-04-07 10:02:31

2009-09-09 15:28:43

Linq to obj

2009-09-18 16:00:07

LINQ架构

2009-09-14 10:57:46

LINQ入门

2009-09-15 16:26:36

Linq orderb

2009-09-22 12:45:00

Hibernate性能

2009-09-28 15:43:42

Hibernate O

2009-09-23 10:58:32

Hibernate T

2009-09-22 11:16:27

Hibernate经验

2009-09-27 13:00:56

Hibernate S

2009-11-20 14:48:07

2009-06-24 16:42:17

JSF和Facelet

2009-09-24 13:17:37

Hibernate类库
点赞
收藏

51CTO技术栈公众号