如何可以将LONG转化为blob clob 区别

hibernate中mysql text类型 用annotation怎么注解啊。。。使用了@Lob 但是确必须是longtext_百度知道
提问者采纳
@Lob 注解属性将被持久化为 Blog 或 Clob 类型。具体的java.sql.Clob, Character[], char[] 和 java.lang.String 将被持久化为 Clob 类型. java.sql.Blob, Byte[], byte[] 和 serializable type 将被持久化为 Blob 类型。@Lob 持久化为Blob或者Clob类型,根据get方法的不同,自动进行Clob和Blob的转换@Lobpublic String getFullText() {
return fullT
// clob type}@Lobpublic byte[] getFullCode() {
return fullC
// blog type}@Lob 通常与@Basic同时使用,提高访问速度。 @Lob @Basic(fetch = FetchType.LAZY) @Column(name=&DtaContent&, columnDefinition=&CLOB&, nullable=true)
public String getDtaContent() {
return dtaC
实体Bean中所有的非Static 非transient的属性都可以被持久化,没有定义注解属性的等价于在其上添加了@Basic注解 通过@Basic注解可以声明属性的获取策略(lazy与否),默认的是即时获取(early fetch),这里又讨论到了 延迟关联获取和延迟属性获取,通常不需要对简单属性设置延迟获取,如需要定义@Basic(fetch=FetchType.LAZY) 希望对您有帮助,如果那里还有疑惑请留言
提问者评价
谢谢,不过你那个还是不行。提示为found text,excepted clob改为columnDefinition=&TEXT&就可以了。
其他类似问题
annotation的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁mybatis如何读取clob数据 详细过程_百度知道
mybatis如何读取clob数据 详细过程
我有更好的答案
按默认排序
例子:表结构CREATE&TABLE&USERINFO(USERID&VARCHAR2(5),&&&&&&&&&&&&&&&&&&&&&&&&&&&&USERNAME&VARCHAR2(20),&&&&&&&&&&&&&&&&&&&&&&&&&&&MEMO&CLOB,&&&&&&&&&&&&&&&&&&&&&&&&&&constraint&PK_USERINFO&&primary&key(USERID));java代码:public&class&OracleClobTypeHandlerCallback&implements&TypeHandlerCallback&{&&&&public&void&setParameter(ParameterSetter&setter,&Object&obj)&&&&&&&&&&&&throws&SQLException&{&&&&&&&&CLOB&clob&=&CLOB.empty_lob();&&&&&&&&clob.setString(1,&(String)obj);&&&&&&&&setter.setClob(clob);&&&&}&&&&public&Object&getResult(ResultGetter&getter)&throws&SQLException&{&&&&&&&&CLOB&clob&=&(CLOB)&getter.getClob();&&&&&&&&return&(clob&==&null&||&clob.length()&==&0&)?&null&:clob.getSubString((long)1,&(int)clob.length());&&&&}&&&&public&Object&valueOf(String&param)&{&&&&&&&&return&&&&&}}sqlmap配置:&resultMap&id=&userResult&&class=&com.prs.application.mon.dto.UserInfoDTO&&&&&&&result&property=&userID&&column=&USERID&&columnIndex=&1&/&&&&&&result&property=&userName&&column=&USERNAME&&columnIndex=&2&/&&&&&&result&property=&memo&&&column=&memo&&jdbcType=&CLOB&&javaType&=&&java.lang.String&&&typeHandler&=&&OracleClobTypeHandlerCallback&&/&&/resultMap&
其他类似问题
mybatis的相关知识
等待您来回答
下载知道APP
随时随地咨询
出门在外也不愁温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
阅读(5795)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_',
blogTitle:'\t\toracle里面的long,long raw,raw,clob,blob区别:',
blogAbstract:'ORACLE LOB类型提供了BFILE、BLOB、CLOB、NCLOB让我们来存储最大尺寸有4G的无结构的数据块(例如:文本、图像、声音和视频等)。并且它们右以以高效的、任意的和分段操作的方式存取数据。&&&
LOB类型在很多方面和LONG和LONG RAW不同,例如,除了NCLOB以外LOB可以被看作对象类型,但是LONG不行。LOB的最大尺寸为4G,但LONg的最大尺寸只有2GB。同时LOB支持随机存取数据,但是LONG中支持顺序存取。&&&
LOB类型存储LOB定位器,它指向一个存储在外部文件的大型对象,PL/SQL通过定位器来操作LOBs。从Oracle9i开始,我们可以将CLOBs转换成CHAR和VARCHAR2,反之亦然。可以使用包DBMS_LOB来对LOB型进行读写的进行分段操作。',
blogTag:'',
blogUrl:'blog/static/0',
isPublished:1,
istop:false,
modifyTime:8,
publishTime:0,
permalink:'blog/static/0',
commentCount:0,
mainCommentCount:0,
recommendCount:0,
bsrk:-100,
publisherId:0,
recomBlogHome:false,
currentRecomBlog:false,
attachmentsFileIds:[],
groupInfo:{},
friendstatus:'none',
followstatus:'unFollow',
pubSucc:'',
visitorProvince:'',
visitorCity:'',
visitorNewUser:false,
postAddInfo:{},
mset:'000',
remindgoodnightblog:false,
isBlackVisitor:false,
isShowYodaoAd:false,
hostIntro:'',
hmcon:'1',
selfRecomBlogCount:'0',
lofter_single:''
{list a as x}
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}如何将varchar2修改为clob类型字段(使用long过渡)
直接从varchar2
修改为clob会报错,不让修改,可以先修改为Long类型,然后从Long修改为clob .
而且更改为long,必须是 ORA-01439: 要修改的資料欄必須是空的,
才可以變更資料庫
Using ALTER TABLE to Convert LONG Columns to LOB
You can use the ALTER TABLE statement in SQL to convert a
LONG column to a LOB
column. To do so, use the following syntax:
ALTER TABLE [&schema&.]&table_name&
MODIFY ( &long_column_name& { CLOB | BLOB | NCLOB }
[DEFAULT &default_value&]) [LOB_storage_clause];
For example, if you had a table that was created
as follows:
CREATE TABLE Long_tab (id NUMBER, long_col LONG);
then you can change the column long_col in table Long_tab to datatype CLOB using following ALTER TABLE statement:
ALTER TABLE Long_tab MODIFY ( long_col CLOB );
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。move一个表到另外一个表空间时,索引不会跟着一起move,而且会失效。(LOB类型例外)
& 表move,我们分为:
*普通表move
*分区表move
*LONG,LOB大字段类型move来进行测试和说明。
& 索引的move,我们通过rebuild来实现
一:move普通表、索引基本语法:
alter table tab_name move tablespace tbs_
move过的普通表,在不用到失效的索引的操作语句中,语句执行正常,但如果操作的语句用到了索引(主键当做唯一索引),则此时报告用到的索引失效,语句执行失败,其他如外键,非空约束,缺省值等不会失效。
我们需要重新创建主键或索引,基本语法为:alter index index_
alter index pk_
如果我们需要move索引,则使用rebuild语法:alter index index_name rebuild tablespace tbs_
alter index pk_name rebuild tablespace tbs_
提示:查询表所具有的索引,可以使用user_indexes视图(索引和主键都在这个视图里可找到)。
& 二:move分区表及索引和普通表一样,索引会失效,区别的仅仅是语法而已。
分区基本语法:特别提醒注意,如果是单级分区,则使用关键字PARTITION,如果是多级分区,则使用SUBPARTITION替代PARTITION。
如果分区或分区索引比较大,可以使用并行move或rebuild,PARALLEL (DEGREE 2);如:ALTER TABLE PART_ALARMTEXTDATA move SUBPARTITION ALARMTEXTDATA_050910_ATD01 TABLESPACE users PARALLEL (DEGREE 2);
ALTER INDEX GLOBAL_ALARMTEXTDATA REBUILD tablespace users PARALLEL (DEGREE 2);
ALTER INDEX LOCAL_ALARMTEXTDATA REBUILD SUBPARTITION ALARMTEXTDATA_050910_ATD01 TABLESPACE users PARALLEL (DEGREE 2);
移动表的某个分区:ALTER TABLE tab_name move PARTITION partition_name TABLESPACE tbs_
重建全局索引:ALTER INDEX global_index REBUILD;或
ALTER INDEX global_index REBUILD tablespace tbs_
注: 分区操作时可以带上with update global indexes选项更新全局索引
重建局部索引:ALTER TABLE tab_name MODIFY PARTITION partition_name REBUILD UNUSABLE LOCAL INDEXES;或ALTER INDEX local_index_name REBUILD PARTITION partition_name TABLESPACE tbs_
USER_PART_TABLES
USER_IND_PARTITIONS
USER_IND_SUBPARTITIONS
USER_LOB_PARTITIONS
USER_LOB_SUBPARTITIONS
USER_PART_INDEXES
USER_PART_LOBS可查询分区相关内容,同时,分区对象,也是segment,所以也可在dba_segments里查的到。
& 三:move LONG,LOB类型(据说DBMS_REDEFINITION包可以提供一些方便,没用过。)
I:LONG类型
LONG类型不能通过MOVE来传输特别提示,尽量不要用LONG类型,特难管理。参考:http://www.anysql.net/2005/12/long_vs_lob.html
LONG不能使用insert into … select …等带select的模式。如create table t123 (id int,en long);则
insert into t123(id,en) select * from t123;报告错误,可以用pl/sql来帮助解决,如:
cursor cur_t123 is select * from t123;
use_t123 cur_t123%
open cur_t123;
fetch cur_t123 into use_t123;
exit when cur_t123%
insert into t123(id,en) values (use_t123.id,use_t123.en);
close cur_t123;
对有LONG类型字段的表的转移,可以使用:
create新表的方法。
* create一个新的表,存储在需要转移的表空间。
* 创建新的索引(使用tablespace 子句指定新的表空间)。
* 把数据转移过来
方法一:用COPY的方法:copy from bigboar/bigboar@bigboar_sid insert t123(id,en) using select id,en from t123;
方法二:PL/SQL(如上)
方法三:直接就把LONG转换成CLOB类型create table t321(id int,en clob)
insert into t321(id,en) select id,to_lob(en) from t123;
方法四:exp/impexp bigboar/bigboar file=a.dat tables=t123
imp bigboar/bigboar file=a.dat full=y IGNORE =y
* drop掉旧表。
* rename 新表为旧表表名。
II:LOB类型在建立含有lob字段的表时,oracle会自动为lob字段建立两个单独的segment,一个用来存放数据(segment_type=LOBSEGMENT),另一个用来存放索引(segment_type=LOBINDEX)。默认它们会存储在和表一起的表空间。我们对表MOVE时,LOG类型字段和该字段的索引不会跟着MOVE,必须要单独来进行MOVE,语法如下如:alter table t321 m
alter table t321 move lob(en) store as (tablespace users);
阅读(...) 评论()

我要回帖

更多关于 blob clob 区别 的文章

 

随机推荐