Oracle还是比较常用的,于是我研究了一下Oracle Clob类型,在这里拿出来和大家分享一下,希望对大家有用。Oracle Clob类型处理解析最近利用NHibernate映射类型为Clob字段在插入数据时发现当字符的字节数(一个半角字符一个字节,一个全角字符两个字节)在 2000-4000之间时报错(ORA-01461:仅可以插入LONG列的LONG值赋值)。Oracle Clob类型方式1:直接将CLOB的值拼写在SQL语句中。代码:
成都创新互联公司专注于乾安网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供乾安营销型网站建设,乾安网站制作、乾安网页设计、乾安网站官网定制、成都微信小程序服务,打造乾安网络公司原创品牌,更为您提供乾安网站排名全网营销落地服务。
- string id = Guid.NewGuid().ToString();
- OracleCommand cmd = Conn.CreateCommand();
- cmd.CommandText = "insert into xx(id,test) values('" + id + "','" + data + "')";
- // data是一个变量,存储你要插入的字符串
- cmd.ExecuteNonQuery();
情况分析:当data的长度大于4000时报错(ORA-01704:文字字符串过长),小于或等于4000时正常插入。
原因分析:之所以会出现长度大于4000时报错,是因为Oracle中有SQL语句中两个单引号之间的字符数不能大于4000的限制。'" + data + "' data在sql语句之间,当data的值大于4000个字节时就会报错。
解决办法:这种方式比较棘手,但有更好的方式,下边会讲到 。
Oracle Clob类型方式2:采用参数形式。代码:
- string id = Guid.NewGuid().ToString();
- OracleCommand cmd = Conn.CreateCommand();
- cmd.CommandText = "insert into xx(id,test) values('" + id + "','" + data + "')";
- // data是一个变量,存储你要插入的字符串
- cmd.ExecuteNonQuery();
情况分析:采用这种方式能够正常插入。所以推荐用这种方式。
原因分析:无
解决办法:无
【编辑推荐】
网站栏目:简单描述Oracle Clob类型
URL链接:http://www.kswsj.com/qtweb/news19/215819.html
网站建设、网络推广公司-成都快上网,一家网站设计、网站制作公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 成都快上网