oracle 的varchar2(4000)通过jdbc的thin驱动连接为什么只可以存666个汉字?
谁说只能存储666个汉字的? insert into T_BOARD values ('测试'); select t.name,length(t.name),lengthb(t.name) from t_board t ![]() 字符集合决定varchar2的长度 问题描述: SQL> select parameter,value from nls_database_parameters where parameter like 'NLS_CHARACTERSET'; PARAMETER 解决方法: SQL> SHUTDOWN IMMEDIATE;
附注1: |
Re: 研究:为什么我的ORACLE的数据操作突然报数量限制的错误(怪)? | 发表时间: 2003-12-05 09:25 |
| |
这是很经典的OracleJDBC问题。一般直接用ps.setString()设置字符串数据时,Oracle的JDBC驱动会将中文转换为2字节或3字节,不固定的,因此经常会越界。 如果你改为ps.setCharacterStream()就是固定的每个中文两个字节 |
根据oracle的文档,thin的jdbc驱动,会根据字符集合决定varchar2的长度,如果不是ascii 或者拉丁字符集合,长度的限制就是2000,因为它认为其他字符集都需要两个字节来存储,但是通过jdbc的setString方法时候,驱动会把 java的utf-16转换为utf-8,这样英文由两个字节变成一个字节,中文由两个字节变为3个字节,所以2000/3大概就是666个中文字符了。
附注2:
pstmt.setBytes(4,aimString.getBytes());
new String(resultSet.getBytes("fieldName"),"ISO-8859-1");