今天用hibernate访问oracle数据库,发现一个问题;
Java代码
<SPANstyle="FONT-SIZE:small">IcaCaCerticaCaCert=IcaCaCert.findByCertSerialNumber(certSerial);</SPAN>
报异常: 流已关闭
看数据库发现有一个长文本字段的类型是:LONG(oracle特有的类型,相当于mysql的longtext)
于是就将该类型更改问clob类型( 不可逆 )
SQL代码
<SPANstyle="FONT-SIZE:small">altertableICA_CA_CERTmodifySIGN_BUF_P7clob;</SPAN>
再次访问没有流已关闭异常,但是又有新的异常: ITRUSCA.ICA_CA_CERT_USER_ID_IND这类索引的分区处于不可用状态
原来原先的表中有索引,我更改类型后索引错误;
重建索引,问题就可解决;
SQL代码
<SPANstyle="FONT-SIZE:small">alterindexITRUSCA.ICA_CA_CERT_USER_ID_INDrebuildonline;</SPAN>
原文链接:http://ligson.iteye.com/blog/1068119