Oracle中LONG在存储过程中的使用
来源:互联网 发布:省份的三级联动数据库 编辑:程序博客网 时间:2024/05/22 04:59
create or replace procedure P_INSERT_TEST(
IDEMO LONG)
is
begin
INSERT INTO T_TEST (ID, DEMO) VALUES (1, IDEMO);
COMMIT;
end P_INSERT_TEST;
以上可以用字符串传递参数,但长度有限制
我还没找到传递LONG参数的方法
Oracle varchar2的范围限制
varchar2
在表中是4000,在过程中可以是32K
过程中的varchar2与表里的varchar2是不一样的。
过程中varchar2型变量的长度可以达到32K,比如你可以往一个clob字段中插入比较长的文本之类的。
varchar2数据类型是一种可变长度的、有最大长度的字母数字型数据。
Varchar2类型的字段长度可以达到4000字节,
Varchar2类型的变量长度可以达到32676字节。
Oracle varchar2的范围限制:
在sql中使用varchar2来定义表时,最大为4000个字符。
在pl/sql中使用varchar2来定义变量时,最大为32K.
另, oracle的integer,int类型为number的子类型,大小可为,-2^38 -- +2^38
Oracle的varchar2(4000)插入汉字过长
在使用oracle时,如果在一个varchar2(4000)的字段上插入的字符过长(一般只能插入666个汉字,视字符集不同会有所不同),会导致失败,具体报错会因驱动版本不同而不同。
原因一:
666 汉字所用的编码里 (可能是 UTF8) 每个字占了 3 bytes,当存的时候, 没有作好 charset-encoding 的转换,造成你的每个 byte 被当成是 java 的一个 char (2 bytes) 来存,这时,每个汉字要用 3x2=6 bytes 存进 oracle 中,所以最多只能存到 4000/6=666 字。
原因二:
这是个OracleJDBC问题。一般直接用ps.setString()设置字符串数据时,Oracle的JDBC驱动会将中文转换为2字节或3字节,不固定的,因此经常会越界。如果改为ps.setCharacterStream()就是固定的每个中文两个字节。
解决办法:
方法一:
使用ps.setCharacterStream()插入多个字符:
原来的代码
//ps.setString(i, ((String) parameter));
String s = (String) parameter;
ps.setCharacterStream(i, new StringReader(s), s.length());
方法二:
不用PreparedStatement,而直接组成sql语句插入。
方法三:
用CLOB字段来解决。
- Oracle中LONG在存储过程中的使用
- 在ORACLE存储过程中使用数组
- 在ORACLE存储过程中使用数组 .
- 在Oracle中使用Java存储过程
- 在Oracle中使用Java存储过程
- oracle 动态SQL在存储过程中的使用
- 如何在Oracle中使用Java存储过程 (详解)
- 如何在Oracle中使用Java存储过程 (详解)
- 如何在Oracle中使用Java存储过程 (详解)
- ORACLE 在存储过程中使用临时表
- 如何在Oracle中使用Java存储过程 (详解)
- 如何在Oracle中使用Java存储过程 (详解)
- 如何在Oracle中使用Java存储过程 (详解)
- 如何在Oracle中使用Java存储过程(详解)
- 如何在Oracle中使用Java存储过程(详解)
- 如何在Oracle中使用Java存储过程(详解)
- 如何在Oracle中使用Java存储过程 (详解) .
- 在Python中使用cx_Oracle调用Oracle存储过程
- 更改虚拟光驱与物理光驱的盘符
- 汉字转换为拼音缩写
- oracle 讨论char varchar varchar2 数据类型选用
- 总结iptables的应用
- ogPHP加密文本文件并限制特定页面的存取
- Oracle中LONG在存储过程中的使用
- 老子的思想与面向对象
- 汇编语言学习六
- dataset 像客户端输出xml
- 三色交替的下拉列表框
- ArcGis Server 9.2下载和全套License
- DebuggerStepThrough特性节省Debug时间
- 单神经元感知机代码
- linux打开ssh服务