willpower88
對JAVA有點理解了……
BlogJava
首頁
新隨筆
聯系
聚合
管理
隨筆-204 評論-90 文章-8 trackbacks-0
用Hibernate操作Oracle Clob字段
1.在HBM里對應CLOB型的字段為:java.sql.Clob,用MyEclipse DataExplorer生成后手動改一下即可,當然POJO也一樣啊,如:
HBM:
<
hibernate-mapping
>
?
<
class?
name
="com.chinacars.filterdata.beans.TblWapNews2"
?table
="TBL_WAP_NEWS2"
>
????????
<
id?
name
="id"
?type
="java.lang.Long"
>
????????????
<
column?
name
="ID"
?precision
="22"
?scale
="0"
?
/>
????????
</
id
>
??????
<
property?
name
="content"
?type
="java.sql.Clob"
>
????????????
<
column?
name
="CONTENT"
?
/>
????????
</
property
>
</
class
>
</
hibernate-mapping
>
POJO:
import
?java.sql.Clob;
public
?
class
?test?
{
???
private
?Clob?content;
???
}
2.首先要給Clob里寫一個值,如:注意看一下有底色的地方就明白了吧
package
?com.chinacars.filterdata.modidata;
import
?java.lang.reflect.InvocationTargetException;
import
?java.sql.Clob;
import
?java.sql.SQLException;
import
?java.util.List;
import
?org.apache.commons.beanutils.PropertyUtils;
import
?org.apache.commons.logging.Log;
import
?org.apache.commons.logging.LogFactory;
import
?org.hibernate.Hibernate;
import
?com.chinacars.filterdata.beans.TblWapNews1;
import
?com.chinacars.filterdata.beans.TblWapNews2;
import
?com.chinacars.filterdata.dao.WapNews1DAO;
import
?com.chinacars.filterdata.dao.WapNews2DAO;
import
?com.chinacars.filterdata.util.StringProcess;
public
?
class
?ModiData2?
{
????
private
?
static
?
final
?Log?logger?
=
?LogFactory.getLog(ModiData2.
class
);
????
public
?
static
?
void
?main(String[]?args)?
{
????????WapNews1DAO?wapNews1DAO?
=
?
new
?WapNews1DAO();
????????WapNews2DAO?wapNews2DAO?
=
?
new
?WapNews2DAO();
????????TblWapNews1?news1?
=
?
new
?TblWapNews1();
????????TblWapNews2?news2?
=
?
new
?TblWapNews2();
????????List?list?
=
?wapNews1DAO.getWapNews();
????????Clob?contentClob?
=
?
null
;
??????
??String?cStr?
=
?
"
1
"
;
????????String?title;
????????
????????
for
?(
int
?i?
=
?
0
;?i?
<
?list.size();?i
++
)?
{
????????????logger.info(
"
============The?number?:?
"
?
+
?i);
????????????news1?
=
?(TblWapNews1)?list.get(i);
????????????contentClob?
=
?news1.getContent();
????????????
try
?
{
????????????????PropertyUtils.copyProperties(news2,?news1);
????????????}
?
catch
?(IllegalAccessException?e)?
{
????????????????logger.error(e);
????????????????e.printStackTrace();
????????????}
?
catch
?(InvocationTargetException?e)?
{
????????????????logger.error(e);
????????????????e.printStackTrace();
????????????}
?
catch
?(NoSuchMethodException?e)?
{
????????????????logger.error(e);
????????????????e.printStackTrace();
????????????}
????????????title?
=
?news1.getTitle();
????????????
if
(title?
!=
?
null
)?
{
????????????????title?
=
?title.replaceAll(
"
?
"
,?
""
);
????????????????news2.setTitle(title);
????????????}
????????????
news2.setContent(Hibernate.createClob(cStr));
????????????
try
?
{
????????????????wapNews2DAO.saveWapNews(news2,?StringProcess
????????????????????????.delInvalidChar(contentClob.getSubString(
1
,
????????????????????????????????(
int
)?contentClob.length())));
????????????????
????????????}
?
catch
?(SQLException?e)?
{
????????????????logger.error(e);
????????????????e.printStackTrace();
????????????}
????????}
????}
}
3.開始寫入這內容,最主要的是這里,我在這里卡了好久……
?? 主是下面紅色的部分,其它的有色部分都能搜到:看下面的代碼吧:^_^
package
?com.chinacars.filterdata.dao;
import
?java.io.Writer;
import
?java.sql.Clob;
import
?oracle.sql.CLOB;
import
?org.apache.commons.logging.Log;
import
?org.apache.commons.logging.LogFactory;
import
?org.hibernate.LockMode;
import
?org.hibernate.Session;
import
?org.hibernate.Transaction;
import
?org.hibernate.lob.SerializableClob;
import
?com.chinacars.filterdata.beans.TblWapNews2;
public
?
class
?WapNews2DAO?
{
????
????
private
?
static
?
final
?Log?logger?
=
?LogFactory.getLog(WapNews2DAO.
class
);
????
private
?Session?oraSession;
????
private
?Transaction?tx;
????
public
?
boolean
?saveWapNews(TblWapNews2?news,?String?content)?
{
????????
try
?
{
????????????oraSession?
=
?SessionFactory.currentORASession();
????????????tx?
=
?oraSession.beginTransaction();
???????????
?oraSession.save(news);
????????????oraSession.flush();
????????????oraSession.refresh(news,?LockMode.UPGRADE);
????????????
????????????
SerializableClob?clob?
=
?(SerializableClob)?news.getContent();
????????????Clob?jClob?
=
?clob.getWrappedClob();
????????????CLOB?oClob?
=
?(CLOB)jClob;
????????????Writer?wt?
=
?oClob.getCharacterOutputStream();????????????
????????????
//
byte[]?bData?=?content.getBytes();
????????????wt.write(content);
????????????wt.close();
????????????oraSession.flush();
????????????tx.commit();
????????????logger.info(
"
===================??INSERT?OK?
"
);
????????}
?
catch
?(Exception?e)?
{
????????????
if
?(tx?
!=
?
null
)
????????????????tx.rollback();
????????????logger.info(
"
===================??NOT?INSERT?
"
);
????????????logger.info(e);
????????????e.printStackTrace();
????????}
?
finally
?
{
????????????oraSession.close();
????????}
????????
return
?
true
;
????}
}
哈哈,就寫到這里了,快沒車了……
有不懂的朋友,發e-mail吧!
erdosqiao@163.com
posted on 2006-05-11 18:40
一凡
閱讀(2153)
評論(0)
編輯
收藏
所屬分類:
JAVA FRAMEWORK
新用戶注冊
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
網站導航:
博客園
IT新聞
Chat2DB
C++博客
博問
管理
相關文章:
Springboot整合activiti
springboot+mybatis整合之坑
在hibernate中配置proxool連接池
Spring配制文件
ajax dwr2.0 學習中遇到的問題
每日訪問數據庫失敗問題
Birt GDI ERROR
hibernate 3.0.x HQL 中文亂碼問題
log4j用法1
hibernate3 hql 參數亂碼問題
<
2006年5月
>
日
一
二
三
四
五
六
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
1
2
3
4
5
6
7
8
9
10
常用鏈接
我的隨筆
我的評論
我的參與
最新評論
留言簿
(9)
給我留言
查看公開留言
查看私人留言
隨筆分類
AI(2)
Android開發
Architecture(1)
DATABASE(44)
Golang(3)
JAVA FRAMEWORK(12)
JAVA IDE(10)
JAVA 基礎(29)
JS$AJAX(6)
linux(47)
Linux C(5)
Network Program(2)
OpenSource(3)
script(2)
Web Server(6)
XML(1)
心情x記(5)
搜索(1)
數據結構&算法(3)
雜文(5)
隨筆檔案
2024年2月 (1)
2023年11月 (1)
2021年8月 (1)
2021年6月 (1)
2021年1月 (1)
2020年9月 (1)
2020年4月 (1)
2020年2月 (1)
2019年12月 (2)
2019年11月 (1)
2019年9月 (1)
2019年4月 (1)
2017年5月 (1)
2017年3月 (1)
2017年2月 (1)
2016年10月 (1)
2015年1月 (1)
2014年11月 (1)
2014年9月 (1)
2014年8月 (1)
2014年7月 (2)
2014年6月 (1)
2014年2月 (2)
2013年12月 (3)
2013年11月 (2)
2013年10月 (2)
2013年6月 (1)
2013年5月 (3)
2013年3月 (2)
2013年2月 (1)
2013年1月 (1)
2012年11月 (1)
2012年10月 (1)
2012年8月 (2)
2012年7月 (3)
2012年4月 (2)
2011年12月 (2)
2011年10月 (1)
2011年9月 (2)
2011年8月 (1)
2011年6月 (1)
2011年3月 (1)
2011年2月 (1)
2010年11月 (1)
2010年10月 (2)
2010年9月 (1)
2010年8月 (5)
2010年7月 (1)
2010年6月 (2)
2010年5月 (7)
2010年4月 (1)
2010年3月 (2)
2010年1月 (2)
2009年10月 (1)
2009年9月 (2)
2009年8月 (3)
2009年7月 (2)
2009年6月 (2)
2009年4月 (1)
2009年3月 (1)
2009年2月 (3)
2008年12月 (2)
2008年11月 (3)
2008年10月 (3)
2008年9月 (1)
2008年8月 (3)
2008年7月 (2)
2008年6月 (4)
2008年5月 (2)
2008年4月 (7)
2008年3月 (3)
2008年2月 (6)
2008年1月 (3)
2007年12月 (3)
2007年11月 (5)
2007年10月 (4)
2007年9月 (1)
2007年8月 (1)
2007年7月 (3)
2007年6月 (2)
2007年5月 (2)
2007年4月 (7)
2007年3月 (5)
2007年2月 (2)
2007年1月 (5)
2006年12月 (7)
2006年11月 (6)
2006年10月 (1)
2006年9月 (2)
2006年8月 (2)
2006年7月 (4)
2006年5月 (1)
2006年4月 (1)
2006年3月 (1)
2006年2月 (2)
文章分類
JAVA FRAMEWORK(1)
Linux(7)
文章檔案
2006年9月 (2)
2006年7月 (1)
2006年6月 (1)
2006年3月 (1)
2006年2月 (3)
相冊
myphoto
學習資源
HSQL、mysql學習筆記
http://labs.renren.com/apache-mirror/
reren apache mirror
jadclipse
java內存溢出
Liferay Portal學習資料
linux command
Lucene-2.0學習文檔
my baby blog
oksonic
sean-Jakarta_Commons_Notes
張沈鵬
搜索引擎lucence
游戲開發
游戲開發
程序性能問題定位方法
苗偉的專欄
雪宇的BLOG
搜索
最新評論
1.?re: 用DOM4J創建及修改XML文件
打
--的
2.?vim打開多窗口、多文件之間的切換
還不錯喲,看得懂吧!
--猴子
3.?vim打開多窗口、多文件之間的切換
猴子增加
--猴子
4.?re: 一些可以查詢IP地理位置、身份證所在地、手機歸屬地的接口
評論內容較長,點擊標題查看
--水年華
5.?re: GlassFish安裝和使用
方法非常
--在中國
閱讀排行榜
1.?vim打開多窗口、多文件之間的切換(33874)
2.?PLS-00103: 出現符號 ","在需要下列之一時(21938)
3.?JAVA日期加減運算(21190)
4.?java發送HTTP GET POST請求(11152)
5.?用DOM4J創建及修改XML文件(10971)
評論排行榜
1.?每日訪問數據庫失敗問題(10)
2.?JAVA日期加減運算(7)
3.?java FTP 操作(摘錄)(7)
4.?eclipse Jadclipse反編譯插件安裝(6)
5.?用Eclipse調用AIX的wsdl2java(5)
Powered by:
博客園
模板提供:
滬江博客
Copyright ©2025 一凡
主站蜘蛛池模板:
亚洲综合成人网在线观看
|
99精品免费观看
|
亚洲国产精品无码中文lv
|
亚洲成AV人片高潮喷水
|
永久免费毛片在线播放
|
成人免费视频一区二区三区
|
四虎影视永久免费观看地址
|
亚洲精品国产精品乱码不卡√
|
老司机亚洲精品影院无码
|
久久免费视频99
|
在线观着免费观看国产黄
|
亚洲国产精品成人精品无码区在线
|
亚洲AV无码久久久久网站蜜桃
|
国产亚洲综合久久
|
久久久精品免费视频
|
女人被男人桶得好爽免费视频
|
亚洲乱码精品久久久久..
|
国产成人久久AV免费
|
亚洲女人18毛片水真多
|
成人电影在线免费观看
|
日韩人妻无码免费视频一区二区三区
|
亚洲成a人无码亚洲成www牛牛
|
国产成人aaa在线视频免费观看
|
亚洲国产成a人v在线观看
|
日韩免费在线视频
|
亚洲国产成人在线视频
|
亚洲成人免费在线
|
亚洲日本久久久午夜精品
|
2015日韩永久免费视频播放
|
永久亚洲成a人片777777
|
亚洲午夜精品一区二区麻豆
|
67194国产精品免费观看
|
亚洲欧美综合精品成人导航
|
国产精品视频免费
|
亚洲高清视频在线观看
|
西西人体免费视频
|
亚洲一区二区精品视频
|
国产成人亚洲综合在线
|
亚洲AV综合色区无码另类小说
|
WWW免费视频在线观看播放
|
四虎AV永久在线精品免费观看
|