今天用hibernate访问oracle数据库,发现一个问题;
Java代码
<span style=”font-size: small;”>IcaCaCert icaCaCert = IcaCaCert.findByCertSerialNumber(certSerial);</span>
报异常: 流已关闭
看数据库发现有一个长文本字段的类型是:LONG(oracle特有的类型,相当于mysql的longtext)
于是就将该类型更改问clob类型( 不可逆 )
Sql代码
<span style=”font-size: small;”>alter table ICA_CA_CERT modify SIGN_BUF_P7 clob;</span>
再次访问没有流已关闭异常,但是又有新的异常: ITRUSCA.ICA_CA_CERT_USER_ID_IND这类索引的分区处于不可oracle账号用状态
原来原先的表中有索引,我更改类型后索引错误;
重建索引,问题就可解决;
Sql代码
<span style=”font-size: small;”>alter index ITRUSCA.ICA_CA_CERT_USER_ID_IND rebuild online;</span>