oracle字符超过2000怎么处理,java-确保Oracle数据库表列中的字符串不超过2000个字节...

要截断错误字符串,以确保它肯定适合Oracle表列VARCHAR2(2000 BYTE)

设计力量:

>主要目标是适应表格列.

> 90-95%的字符串文本是异常消息和堆栈跟踪.但是它可能包含一些带有法语,土耳其语字符的客户名称,我愿意忽略这些客户名称并将其视为?管他呢.

>我希望代码变得简单.数据库编码可以更改.可以引入中文字符,但无论如何我都希望代码能够工作.

应该是“简单的”,但这让我琢磨了一段时间.

有什么建议?

最好的选择可能是转换为ascii.但是我想出了一个变种,虽然不太好但是可能可行.

public static String trimStringToBytes(StringBuilder builder, int maximumBytes)

{

String truncatedString = builder.length() > maximumBytes ? builder.substring(0, maximumBytes) : builder.toString();

byte[] bytes;

String asciiCharsetName = "US-ASCII";

try

{

bytes = truncatedString.getBytes(asciiCharsetName);

}

catch (UnsupportedEncodingException e)

{

//not really possible as JVM should support always US-ASCII but anyway

int worstCaseScenarioBytesPerCharacter = 4;

bytes = truncatedString.substring(0, truncatedString.length() / worstCaseScenarioBytesPerCharacter).getBytes();

}

return new String(bytes, 0, bytes.length > maximumBytes ? maximumBytes : bytes.length);

}

解决方法:

我建议不要在Java中执行此操作,而是在执行INSERT时在SQL中执行此操作.

例如,在Oracle中,可以使用SUBSTR函数通过connection.prepareStatement进行修整:

insert into mytable (col1, col2) values (?, substr(?, 0, 2000));

然后在PreparedStatement上设置col1和col2值,Oracle应该获取该值的前2000个字符/字节/无论它是什么,然后进行设置.

使用存储过程甚至可能值得这样做,将整个String作为VARCHAR2参数传递给该过程,然后对它进行修剪并插入行.无需应用程序参与基础存储语义.

标签:oracle,character-encoding,java

来源: https://codeday.me/bug/20191210/2101766.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值