使用hibernate执行查询时,报如下异常:
Caused by: java.sql.SQLException: 无法从套接字读取更多的数据
at oracle.jdbc.driver.SQLStateMapping.newSQLException(SQLStateMapping.java:74)
at oracle.jdbc.driver.DatabaseError.newSQLException(DatabaseError.java:110)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:171)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:227)
at oracle.jdbc.driver.DatabaseError.throwSqlException(DatabaseError.java:439)
at oracle.jdbc.driver.T4CMAREngine.unmarshalUB1(T4CMAREngine.java:1042)
at oracle.jdbc.driver.T4CMAREngine.unmarshalSB1(T4CMAREngine.java:999)
at oracle.jdbc.driver.T4C7Ocommoncall.receive(T4C7Ocommoncall.java:97)
at oracle.jdbc.driver.T4CConnection.doRollback(T4CConnection.java:613)
at oracle.jdbc.driver.PhysicalConnection.rollback(PhysicalConnection.java:3389)
at org.apache.commons.dbcp.DelegatingConnection.rollback(DelegatingConnection.java:265)
at org.apache.commons.dbcp.DelegatingConnection.rollback(DelegatingConnection.java:265)
at org.apache.commons.dbcp.PoolingDataSource$PoolGuardConnectionWrapper.rollback(PoolingDataSource.java:288)
at org.hibernate.transaction.JDBCTransaction.rollbackAndResetAutoCommit(JDBCTransaction.java:183)
at org.hibernate.transaction.JDBCTransaction.rollback(JDBCTransaction.java:162)
... 21 more
我的SQL代码如下:
select *
from (select EIPOD_ID,
EIPOD_BK_VESSEL,
EIPOD_BK_VOYAGE,
EIPOD_WB_NO,
EIPOD_DISC_PORT_ID,
EIPOD_CONSIGNEE_NAME,
CNT_NOS,
GROSS_WEIGHT,
EXECUTIVES,
ADDRESSES,
RELEASE_WEIGHT
from (select EIPOD.CREATE_TIME,
EIPOD.EIPOD_ID,
EIPOD.EIPOD_BK_VESSEL,
EIPOD.EIPOD_BK_VOYAGE,
EIPOD.EIPOD_WB_NO,
EIPOD.EIPOD_DISC_PORT_ID,
EIPOD.EIPOD_CONSIGNEE_NAME,
GET_CNT_NO(EIPOD.EIPOD_ID, ',') CNT_NOS,
nvl((select sum(EIPCI.EIPCI_GROSS_WEIGHT)
from EIP_CTNINFO EIPCI
where EIPCI.EIPCI_EIPOD_ID = EIPOD.EIPOD_ID),
0) GROSS_WEIGHT,
GET_DELIVER_EXECUTIVES(EIPOD.EIPOD_ID, ',') EXECUTIVES,
GET_DELIVER_ADDRESSES(EIPOD.EIPOD_ID, ',') ADDRESSES,
nvl((select sum(EIPMP_GROSS_WEIGHT)
from EIP_MUTIL_PLACE EIPMP
where exists (select 1
from EIP_CTNINFO EIPCI
where EIPCI.EIPCI_ID =
EIPMP.EIPMP_EIPCI_ID
and EIPCI.EIPCI_EIPOD_ID =
EIPOD.EIPOD_ID)),
0) RELEASE_WEIGHT
from EIP_ORDER EIPOD
left join SCH_VOYAGE SCHVO on EIPOD.EIPOD_SCHVO_ID =
SCHVO.SCHVO_ID
left join VES_SHIP_BASE_INFO VESSI on SCHVO.SCHVO_VESSEL_ID =
VESSI.VESSI_ID
where EIPOD.EIPOD_BK_CONFIRMED_FLAG = '4'
and EIPOD.EIPOD_IS_VALID != '0'
and EIPOD.EIPOD_WB_NO like 'SUN1104230007' || '%'
and ((1 = 1)))
where GROSS_WEIGHT > 0
order by CREATE_TIME desc)
where rownum <= 20
解决此异常有两个方法:
1、加大数据库的回滚段
2、修改SQL语句,下面SQL是我所作的修改,仅供参考:
select *
from (select EIPOD_ID,
EIPOD_BK_VESSEL,
EIPOD_BK_VOYAGE,
EIPOD_WB_NO,
EIPOD_DISC_PORT_ID,
EIPOD_CONSIGNEE_NAME,
CNT_NOS,
GROSS_WEIGHT,
EXECUTIVES,
ADDRESSES,
RELEASE_WEIGHT
from (select EIPOD.CREATE_TIME,
EIPOD.EIPOD_ID,
EIPOD.EIPOD_BK_VESSEL,
EIPOD.EIPOD_BK_VOYAGE,
EIPOD.EIPOD_WB_NO,
EIPOD.EIPOD_DISC_PORT_ID,
EIPOD.EIPOD_CONSIGNEE_NAME,
GET_CNT_NO(EIPOD.EIPOD_ID, ',') CNT_NOS,
nvl(EIP.EIPCI_GROSS_WEIGHT, 0) GROSS_WEIGHT,
GET_DELIVER_EXECUTIVES(EIPOD.EIPOD_ID, ',') EXECUTIVES,
GET_DELIVER_ADDRESSES(EIPOD.EIPOD_ID, ',') ADDRESSES,
nvl((select sum(EIPMP_GROSS_WEIGHT)
from EIP_MUTIL_PLACE EIPMP
where exists (select 1
from EIP_CTNINFO EIPCI
where EIPCI.EIPCI_ID =
EIPMP.EIPMP_EIPCI_ID
and EIPCI.EIPCI_EIPOD_ID =
EIPOD.EIPOD_ID)),
0) RELEASE_WEIGHT
from EIP_ORDER EIPOD
left join SCH_VOYAGE SCHVO on EIPOD.EIPOD_SCHVO_ID =
SCHVO.SCHVO_ID
left join VES_SHIP_BASE_INFO VESSI on SCHVO.SCHVO_VESSEL_ID =
VESSI.VESSI_ID
left join (select EIPCI_EIPOD_ID,
sum(EIPCI.EIPCI_GROSS_WEIGHT) EIPCI_GROSS_WEIGHT
from EIP_CTNINFO EIPCI
group by EIPCI.EIPCI_EIPOD_ID) EIP on EIP.EIPCI_EIPOD_ID =
EIPOD.EIPOD_ID
where EIPOD.EIPOD_BK_CONFIRMED_FLAG = '4'
and EIPOD.EIPOD_IS_VALID != '0'
and EIPOD.EIPOD_WB_NO like 'SUN1104230007' || '%'
and ((1 = 1)))
where GROSS_WEIGHT > 0
order by CREATE_TIME desc)
where rownum <= 20
分享到:
相关推荐
java.sql.SQLException: 不支持的字符集 (在类路径中添加 orai18n.jar): ZHS16GBK ……
NULL 博文链接:https://listen-raining.iteye.com/blog/1962065
在oracle里面运行一下,解决Exception java.sql.SQLException ORA-00600 内部错误代码
NULL 博文链接:https://zhang-zling.iteye.com/blog/980488
服务器出现java.sql.SQLException No suitable driver found for 的
oracle ora-各种常见java.sql.SQLException归纳
java.sql.SQLException: null, message from server: “Host ‘223.72.41.7’ is not allowed to connect to this MySQL server” 客户端访问时报错: 解决方法: 1,登陆服务器 mysql> use mysql; //用mysql ...
本文主要介绍了关于MySQL存储表情报错:java.sql.SQLException: Incorrect string value: ‘\xF0\x9F\x92\xA9\x0D\x0A…’的相关解决方法,分享出供大家参考学习,下面话不多说了,来一起看看详细的介绍: ...
oracle 10g 数据库驱动下载:oracle jdbc dirver
主要给大家介绍了关于MySQL存储表情时报错:java.sql.SQLException: Incorrect string value: 'xF0x9Fx92xA9x0Dx0A...'的解决方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
Q: I am working with ... I am using updateBinaryStream method of resultset to update the BLOB field but it is failing after giving following exception java.sql.SQLException: Internal Error: Unable to
mysql5.6连接驱动jaf,可处理报错java.sql.SQLException: No suitable driver
异常错误:java.sql.SQLException: The server time zone value ‘?й???’ is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTime...
java.sql.SQLException: Operation not allowed after ResultSet closed java.sql.SQLException: QueryRunner requires a DataSource to be invoked in this way, or a Connection should be passed in
问题是这样的…我在VS2008直接运行打开网页,可以连接... 异常详细信息: System.Data.SqlClient.SqlException: 无法打开登录所请求的数据库 “TakeClass”。登录失败。 用户 ‘2D2727E2578F446\ASPNET’ 登录失败。
异常详细信息: System.Data.SqlClient.SqlException: 用户 'sa' 登录失败。该用户与可信 SQL Server 连接无关联。 说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中...
import java.sql.SQLException; import java.sql.Statement; import java.sql.ResultSet; /** * @author Administrator * */ public class sqlServer { String DBDriver=...
绝对好用的9i驱动包+10g驱动包 解决java.sql.SQLException: 不支持的特性 解决oracle.jdbc.driver.OracleDatabaseMetaData.supportsGetGeneratedKeys()Z异常 等等
Caused by: java.sql.SQLException: java.lang.ClassNotFoundException: org.apache.hive.jdbc.HiveDriver at com.trs.gateway.commons.hive.HiveFeature.getConnection(HiveFeature.java:57) at ...