最近,使用Hibernate操作Clob。上网看了不少资料,感觉五花八门,实现起来的方法都各不相同。
有的是Hibernate2.0上的。有的是加入了spring的支持,把clob当成string做处理(的确很好,但是不适合新手)
........
而且,某些代码根本都执行不了~浪费我们的时间,55555555。
于是,法老参考了一些官网的方法加以修改,干脆重新写一个完整元操作版本。
包含:insert,update,delete,select 四大基本方法!
供大家参考!
-------------------------------------------
测试环境介绍:
WINDWOS XP SP2;Eclipse 3.2;JDK 1.4.2
Hibernate-Version: 3.0.5 ; oracle 9i ;
=====================
重点说明:
1。配置文件hbm.xml里把clob的type="clob"
片段如下
<property name="bsznContent"
type="clob">
<column name="BSZN_CONTENT" not-null="true" />
</property>
2。实体bean中,导入
java.sql.Clob包 (注意不是
oracle.sql.CLOB 个人习惯用血统纯点的.这里鄙视一下oracle。嘿嘿)
在该字段对应的实体文件里面,增加以下两个变量及其相应的get/set方法import java.sql.Clob;
...
private Clob
bsznContent;
private String
bsznContentString;...
public Clob
getBsznContent() {
return this.bsznContent;
}
public void
setBsznContent(Clob bsznContent) {
this.bsznContent = bsznContent;
}
public String
getBsznContentString() {
return bsznContentString;
}
public void
setBsznContentString(String bsznContentString) {
this.bsznContentString = bsznContentString;
}
bsznContent 属性是默认的clob,
bsznContentString 属性是对
bsznContent做转换时候用的
----------------------------------------
好了废话不多说,把代码写下来吧~
建表SQL=================
/**//* Table: "cmp_bszn" 相关SQL */
/**//*==============================================================*/
create table "cmp_bszn" (
"id" INTEGER not null,
"kind" CHAR(2) not null,
"bszn_title1" VARCHAR2(200) not null,
"bszn_title2" VARCHAR2(200),
"bszn_code" VARCHAR2(50),
"bszn_bumen" VARCHAR2(50),
"bszn_date" VARCHAR2(50),
"bszn_content" CLOB not null,
"sys_date" DATE default SYSDATE not null,
constraint PK_CMP_BSZN primary key ("id")
); hibernate.cfg.xml 由于调试用,用的是JDBC连接方法,要使用连接池,请自行修改.
记得自己把数据库地址和用户名,秘密改下
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<property name="connection.username">sa</property>
<property name="connection.url">
jdbc:oracle:thin:@127.0.0.1:1521:web
</property>
<property name="dialect">
org.hibernate.dialect.Oracle9Dialect
</property>
<property name="connection.password">saweb</property>
<property name="connection.driver_class">
oracle.jdbc.driver.OracleDriver
</property>
<property name="show_sql">true</property>
<property name="connection.useUnicode">true</property>
<property name="connection.characterEncoding">GBK</property>
<!-- 設定事務管理的工廠類 -->
<property name="hibernate.transaction.factory_class">
org.hibernate.transaction.JDBCTransactionFactory
</property>
<property name="hibernate.query.factory_class">
org.hibernate.hql.classic.ClassicQueryTranslatorFactory
</property>
<mapping resource="clob/cmpBszn.hbm.xml" />
</session-factory>
</hibernate-configuration> cmpBszn.hbm.xml
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!--
Mapping file autogenerated by MyEclipse - Hibernate Tools
-->
<hibernate-mapping>
<class name="cmpBszn" table="CMP_BSZN" schema="SA">
<id name="id" type="java.lang.Long">
<column name="ID" precision="22" scale="0" />
<generator class="increment"></generator>
</id>
<property name="kind" type="java.lang.String">
<column name="KIND" length="2" not-null="true" />
</property>
<property name="bsznTitle1" type="java.lang.String">
<column name="BSZN_TITLE1" length="200" not-null="true" />
</property>
<property name="bsznTitle2" type="java.lang.String">
<column name="BSZN_TITLE2" length="200" />
</property>
<property name="bsznCode" type="java.lang.String">
<column name="BSZN_CODE" length="50" />
</property>
<property name="bsznBumen" type="java.lang.String">
<column name="BSZN_BUMEN" length="50" />
</property>
<property name="bsznDate" type="java.lang.String">
<column name="BSZN_DATE" length="50" />
</property>
<property name="bsznContent" type="clob">
<column name="BSZN_CONTENT" not-null="true" />
</property>
<property name="sysDate" type="java.util.Date">
<column name="SYS_DATE" length="7" not-null="true" />
</property>
</class>
</hibernate-mapping>
抽象类AbstractcmpBszn.java
// default package
import java.sql.Clob;
import java.util.Date;
/** *//**
* AbstractcmpBszn generated by MyEclipse - Hibernate Tools
*/
public abstract class AbstractcmpBszn implements java.io.Serializable ...{
// Fields
private Long id;
private String kind;
private String bsznTitle1;
private String bsznTitle2;
private String bsznCode;
private String bsznBumen;
private String bsznDate;
private Clob bsznContent;
private String bsznContentString;
private Date sysDate;
// Constructors
/** *//** default constructor */
public AbstractcmpBszn() ...{
}
/** *//** minimal constructor */
public AbstractcmpBszn(String kind, String bsznTitle1, Clob bsznContent, Date sysDate) ...{
this.kind = kind;
this.bsznTitle1 = bsznTitle1;
this.bsznContent = bsznContent;
this.sysDate = sysDate;
}
/** *//** full constructor */
public AbstractcmpBszn(String kind, String bsznTitle1, String bsznTitle2, String bsznCode, String bsznBumen, String bsznDate, Clob bsznContent, Date sysDate) ...{
this.kind = kind;
this.bsznTitle1 = bsznTitle1;
this.bsznTitle2 = bsznTitle2;
this.bsznCode = bsznCode;
this.bsznBumen = bsznBumen;
this.bsznDate = bsznDate;
this.bsznContent = bsznContent;
分享到:
相关推荐
关于Clob类型在Hibernate中 的应用小结关于Clob类型在Hibernate中 的应用小结关于Clob类型在Hibernate中 的应用小结关于Clob类型在Hibernate中 的应用小结
介绍了利用Hibernate将一个长字符串转换为流存储至Clob字段中,然后再从Clob字段中读出来,转换为字符串输出的方式
hibernate存取oracle的clob
Hibernate对BLOB CLOB操作,详细的操作说明
使用Hibernate映射Blob,Clob字段,并对这些字段完成存,取功能
hibernate动态映射表处理oralce10g的clob类型,压缩包为整个工程包. 真诚地希望能帮到你,同时真诚地希望你能和我交流, about any question^_^
数据库中clob类型转换的问题 数据库中clob类型转换的问题
mybatis 对clob类型转换,解决clob类型数据插入数据库报异常问题
运用Java如何存取Oracle中的CLOB类型字段
关于Oracle的 Clob数据类型在Hibernate中的应用小结
oracle的jdbc驱动程序,用这个版本的操作Clob,blob类型的数据很方便。 博文链接:https://zhenjw.iteye.com/blog/173419
hibernate Blob、Clob字段的映射的例子.数据库mysql,数据库放在文件夹里面,例子的说明文章在我的csdn blog: http://blog.csdn.net/zhengcandan
java操作oracle clob,基础教程,教你clob在java中的用法,简单易学。
是我自己验证过的 用的是oracle10数据库 文件里面有具体的配置。
这种做法不必处理clob(Character Large Object), blob(Binary Large Object)等格式的字段类型,但不易做transaction的控制,而且增加了对文件的处理操作,不算是较佳的一个方案。另一个做法是使用clob, blob等字段...
J2EE开发中,经常会遇到存储大文本的文字信息,而oracle数据库的vachar字段最大能存储4000个字节,存储更大的信息必须使用clob或blob字段,本文档就是针对j2ee开发中对colb字段操作的实现。
Mybatis 处理 CLOB、BLOB 类型数据
主要是整合了jdbc处理clob类型的增删改查方法,有需要的同学可以看下