[20130513]给lob字段命名的问题.txt

简介: [20130513]给lob字段命名的问题.txt前几天同事建议把一些表移动到其他表空间,主要是增长太快.在测试时忘记移动lob字段,这样效果不大.我突然想能否lob字段命名一个好名字,这样看到这个字段就知道它属于这个表.
[20130513]给lob字段命名的问题.txt

前几天同事建议把一些表移动到其他表空间,主要是增长太快.在测试时忘记移动lob字段,这样效果不大.
我突然想能否lob字段命名一个好名字,这样看到这个字段就知道它属于这个表.

自己在测试环境做一些测试:

1.测试环境:
SQL> @ver
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production

create table t( id number,image blob);

SQL> select table_name,column_name,segment_name,tablespace_name,index_name  from dba_lobs where wner=user and table_name='T';
TABLE_NAME COLUMN_NAME          SEGMENT_NAME         TABLESPACE_NAME                INDEX_NAME
---------- -------------------- -------------------- ------------------------------ ------------------------------
T          IMAGE                SYS_LOB0000274635C00 USERS                          SYS_IL0000274635C00002$$
                                002$$

--274635标识表T的object_id,2表示第2个字段.

SQL> select object_id,data_object_id from dba_objects where wner=user and object_name='T';
 OBJECT_ID DATA_OBJECT_ID
---------- --------------
    274635         274635

--很明显如果知道SYS_LOB0000274635C00002$$,要知道是那个表的lob字段,要查询dba_lobs视图.

SQL> select table_name,column_name,segment_name,tablespace_name,index_name  from dba_lobs where SEGMENT_NAME='SYS_LOB0000274635C00002$$';
TABLE_NAME COLUMN_NAME          SEGMENT_NAME         TABLESPACE_NAME                INDEX_NAME
---------- -------------------- -------------------- ------------------------------ ------------------------------
T          IMAGE                SYS_LOB0000274635C00 USERS                          SYS_IL0000274635C00002$$
                                002$$
2.如何改名呢?
先试验按照常规方法修改索引:
SQL> alter index "SYS_IL0000274635C00002$$" rename to T_IMAGE_IDX;
alter index "SYS_IL0000274635C00002$$" rename to T_IMAGE_IDX
*
ERROR at line 1:
ORA-22864: cannot ALTER or DROP LOB indexes
--行不通.

--抽取定义:
select dbms_metadata.get_ddl('TABLE','T') from dual;
  CREATE TABLE "SCOTT"."T" 
   (    "ID" NUMBER, 
    "IMAGE" BLOB
   ) SEGMENT CREATION DEFERRED 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  TABLESPACE "USERS" 
 LOB ("IMAGE") STORE AS BASICFILE (
  TABLESPACE "USERS" ENABLE STORAGE IN ROW CHUNK 8192 RETENTION 
  NOCACHE LOGGING ) 

--不知道如何修改.仔细看一些手册,写成

CREATE TABLE "SCOTT"."T"
   (    "ID" NUMBER, 
    "IMAGE" BLOB
   ) SEGMENT CREATION DEFERRED 
  PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 
 NOCOMPRESS LOGGING
  TABLESPACE "USERS" 
 LOB ("IMAGE") STORE AS  BASICFILE t_image_lob (
  TABLESPACE "USERS" ENABLE STORAGE IN ROW CHUNK 8192 RETENTION 
  NOCACHE LOGGING ) ;

测试看看.通过.

SQL> select table_name,column_name,segment_name,tablespace_name,index_name  from dba_lobs where wner=user and table_name='T';
TABLE_NAME COLUMN_NAME          SEGMENT_NAME         TABLESPACE_NAME                INDEX_NAME
---------- -------------------- -------------------- ------------------------------ ------------------------------
T          IMAGE                T_IMAGE_LOB          USERS                          SYS_IL0000274638C00002$$

--建立的段名已经T_IMAGE_LOB.对应的索引依旧不行.再仔细看手册加上一个google,找到如下链接:
http://www.dbaglobe.com/2010/06/lobsegment-defragmentation.html
写成如下:

drop table t purge;
create table t( id number,image blob)
    LOB ( image) STORE AS BASICFILE t_image_lob (
      TABLESPACE users
      ENABLE STORAGE IN ROW
      INDEX t_image_idx ( TABLESPACE users ));

SQL> select table_name,column_name,segment_name,tablespace_name,index_name  from dba_lobs where wner=user and table_name='T';
TABLE_NAME COLUMN_NAME          SEGMENT_NAME         TABLESPACE_NAME                INDEX_NAME
---------- -------------------- -------------------- ------------------------------ ------------------------------
T          IMAGE                T_IMAGE_LOB          USERS                          T_IMAGE_IDX

3.顺便测试一下move的情况:

SQL> insert into t values (1,lpad('a',4000,'a'));
1 row created.

SQL> commit;
Commit complete.

SQL> alter table t move tablespace test lob (image) store as( tablespace test );

SQL> select * from dba_extents where wner=user and segment_name in ('T_IMAGE_LOB','T_IMAGE_IDX','T');
OWNER  SEGMENT_NAME   SEGMENT_TYPE       TABLESPACE_NAME   EXTENT_ID    FILE_ID   BLOCK_ID      BYTES     BLOCKS RELATIVE_FNO
------ -------------- ------------------ ---------------- ---------- ---------- ---------- ---------- ---------- ------------
SCOTT  T_IMAGE_LOB    LOBSEGMENT         TEST                      0          8        144      65536          8            8
SCOTT  T_IMAGE_IDX    LOBINDEX           TEST                      0          8        152      65536          8            8
SCOTT  T              TABLE              TEST                      0          8        160      65536          8            8

--很明显索引也一起移动了.


--执行如下,效果也一样.

SQL> alter table t move tablespace test lob (image) store as( tablespace test index t_image_idx (tablespace test) );
Table altered.

SQL> select * from dba_extents where wner=user and segment_name in ('T_IMAGE_LOB','T_IMAGE_IDX','T');
OWNER  SEGMENT_NAME  SEGMENT_TYPE       TABLESPACE_NAME   EXTENT_ID    FILE_ID   BLOCK_ID      BYTES     BLOCKS RELATIVE_FNO
------ ------------- ------------------ ---------------- ---------- ---------- ---------- ---------- ---------- ------------
SCOTT  T_IMAGE_LOB   LOBSEGMENT         TEST                      0          8        168      65536          8            8
SCOTT  T_IMAGE_IDX   LOBINDEX           TEST                      0          8        176      65536          8            8
SCOTT  T             TABLE              TEST                      0          8        184      65536          8            8


目录
相关文章
|
Oracle 关系型数据库 测试技术
[20180416]clob的插入.txt
[20180416]clob的插入.txt --//论坛上有人问的问题,如何限制BLOB字段的大小,用户只能上传15K至30K的图片,超过30K就不给上传. --//链接:http://www.
1083 0
|
关系型数据库 Oracle 开发工具
[20170508]listagg拼接显示字段.txt
[20170508]listagg拼接显示字段.txt --//记得前一阵子,要给表增加一个字段,并赋值.采用表在线重定义.要使用函数dbms_redefinition.
892 0
|
Oracle 关系型数据库 OLAP
[20160910]快速修改表的schema.txt
[20160910]快速修改表的schema.txt --以前也做过例子: http://blog.itpub.net/267265/viewspace-741154/ http://blog.itpub.net/267265/viewspace-744787/ --第1种就是修改数据字典的情况,但是这种存在一定的风险,我当时的测试版本11.2.0.1还有修改obj$的字段spare3. --第2种就是利用交换分区的方法。
843 0
|
Oracle 关系型数据库 测试技术
[20150314]256列.txt
[20150314]256列.txt --oracle 当1个表超过256列时,要分成几个行片(row pieces),昨天看链接: https://jonathanlewis.
840 0
|
测试技术
[20141116]12c下增加字段与缺省值.txt
[20141116]12c下增加字段与缺省值.txt --前一段时间写了一篇表增加字段与缺省值的blog. --链接如下: http://blog.itpub.net/267265/viewspace-1257035/ --12G 增加字段带缺省值,可以很快完成,不需要update表.实际上是增加一个隐含字段,通过位与的方式确定取值方式。
833 0
[20140823]11g增加字段与缺省值.txt
[20140823]11g增加字段与缺省值.txt --12c 当插入NULL时可以指定缺省值.不知道为什么设置这个特性,有点怪怪的.自己先测试11G增加字段带缺省值的情况.
708 0
|
存储 SQL 机器学习/深度学习
[20140729]关于LOB字段存储特性1.txt
[20140729]关于LOB字段存储特性1.txt CLOB/BLOB字段的存储可以使用参数ENABLE/DISABLE STORAGE IN ROW,默认是ENABLE STORAGE IN ROW,这种情况下,如果 保存长度小于等于3964(主要前面占用36字节),实际上总和是4000字节.
993 0
|
存储 关系型数据库 Oracle
[20140729]关于LOB字段存储特性3.txt
[20140729]关于LOB字段存储特性3.txt --前面我们看到只要lob信息在块外,扫描执行读到这些信息都存在物理读。 SCOTT@test> @ver BANNER ------------------------------------...
860 0
|
存储 机器学习/深度学习 索引
[20140729]关于LOB字段存储特性2.txt
[20140729]关于LOB字段存储特性2.txt --前面提到查询字段是DISABLE STORAGE IN ROW的读会增加,从4->11. 多扫描lob index 来定位信息,但是增加也太多。
784 0