向ORACLE插入clob的错误,大家指点。

rextan 2005-09-05 05:06:21
Caused by: java.sql.SQLException: Io 异常: End of TNS data channel

at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:134)

at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:179)

at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:333)

at oracle.jdbc.driver.OracleConnection.rollback(OracleConnection.java:1380)

at net.sf.hibernate.transaction.JDBCTransaction.rollback(JDBCTransaction.java:86)
请教这个是什么错误啊?该怎么解决?
...全文
164 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
Philzzf 2005-09-05
  • 打赏
  • 举报
回复
分别试一下以下各方法:

1.把thin连接换成oci连接试一下看

2.找最新的oracle 10g的jdbc驱动试一下看

3.在hibernate的配置文件里加上 <property name="hibernate.jdbc.batch_size">0</property>试试看

4.
加入这个类:ClobType.java
----------------------------
import java.sql.Clob;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import java.io.StringReader;

import net.sf.hibernate.HibernateException;
import net.sf.hibernate.type.ImmutableType;
import org.apache.commons.lang.ObjectUtils;

public class ClobType extends ImmutableType {
public Object get(ResultSet rs, String name)
throws HibernateException, SQLException {
Clob clob = rs.getClob(name);
if(clob!=null){
return clob.getSubString(1, (int) clob.length());
}else{
return "";
}
}

public void set(PreparedStatement st, Object value, int index)
throws SQLException {
StringReader r = new StringReader((String) value);
st.setCharacterStream(index, r, ((String) value).length());
}

public int sqlType() {
return Types.CLOB;
}

public String getName() {
return "string";
}

public boolean hasNiceEquals() {
return false;
}

public boolean equals(Object x, Object y) {
return ObjectUtils.equals(x, y);
}

public String toXML(Object value) {
return (String) value;
}

public Class getReturnedClass() {
return Clob.class;
}

public Object fromStringValue(String xml) {
throw new UnsupportedOperationException();
}

public String toString(Object value) {
return value.toString();
}

public Object nullSafeGet(ResultSet rs, String[] names, Object owner)throws HibernateException, SQLException {
Clob clob = rs.getClob(names[0]);
return (clob == null ? null : clob.getSubString(1, (int) clob.length()));
}

}

然后在hibernate-mapping文件里对clob的字段按下面的方式定义:
<property name="content" type="刚才加入的类的包名.ClobType" />



内容概要:本文介绍了软件定义汽车(SDV)的最佳实践案例,重点围绕基于Vector技术的电子电气(E/E)架构设计与实现。文档展示了高算力计算平台(HPC)、区域控制器(Zone ECU)和车载网络(如CAN、Ethernet)的系统架构布局,并结合AUTOSAR操作系统(Classic/Adaptive)、虚拟化(Hypervisor)和SOA服务设计,构建现代化车载系统。通过vCANdrive平台演示了从开发、测试(SIL/HIL)、到OTA升级的全流程,涵盖传感器、执行器、应用层软件及云端协同的集成方案。同时展示了硬件原型(如树莓派、Triboard)和MICROSAR系列工具链在实际项目中的应用。; 适合人群:从事汽车电子系统开发、车载软件架构设计以及智能网联汽车研发的工程师和技术管理人员,具备一定的嵌入式系统或AUTOSAR基础者更佳。; 使用场景及目标:①理解软件定义汽车的整体架构设计方法;②掌握基于Vector工具链的HPC与区域控制器集成方案;③实现OTA更新、SIL/HIL测试、ETH-CAN通信转换等关键技术验证;④支持智能驾驶(ADAS)与智能座舱(IVI)系统的快速原型开发。; 阅读建议:建议结合Vector相关工具(如PREEvision、CANoe4SW、MICROSAR)进行实践操作,重点关注系统分层设计、通信机制与软件更新流程,同时可参考文档中的硬件连接示意图与信号映射关系进行仿真与实车验证。

62,630

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧