三招让Oracle表列管理更加简单
2009-05-27 13:16:21 来源:WEB开发网除了给表添加注释外,在Oracle数据库中还可以给列添加注释。这个添加的方法跟上面的类似,只需要把关键字ON TABLE更改为ON COLUMN 即可。当有多个人共同开发一个数据库时,最好能够在表或者列中添加必要的注释。即使不在这里添加说明,那么在独立的设计文档中,也需要进行详细的说明。一般情况下,笔者认为需要说明如下内容。一是创建者(谁创建的或者谁更新的);二是创建的时间(什么时候创建或者什么时候更新的);三是需要注明创建或者更新的目的;四是要注明这个列的一些约束条件。另外需要注意的是,如果后来有人更新这个表或者列的时候,如调整某个字段的大小,最好不要把原先的注释覆盖掉。而是直接在原有的注释后面加入新的注释。这些措施有利于后续的维护以及数据库的升级。
三、 重新组织表。
有时候出于改善数据库表的性能等目的出发,需要对Oralce数据库的表进行重新组织。如在Oracle数据库中,如果对表进行频繁的DML操作,会使得这个表产生比较多的空间碎片与行迁移,从而给数据库的性能带来负面影响。这种情况在一些事务型的数据库中是比较常见的。此时就需要重新组织表,如可以将移动一个位置,从而减少碎片,提高数据库的性能。
大部分情况下,笔者都是利用ALTER TABLE MOVE语句来重新组织表。如可以利用这条语句,将某个表移动到同一个表空间的新数据段中。移动以后这对于用户来说是没有任何影响的。但是却可以重建表的存储结构,从而减少碎片,优化性能。当然,也可以利用这个语句把现有的表移动到其他的表空间中去。不过在使用这个语句的时候,数据库管理员还是需要注意几个限制。
一是在使用这条语句中要注意有足够的空闲空间;如果在同一个表空间进行移动的话,则需要主要表空间能够容纳这个数据。这注意是因为,这个操作就好像是两个操作结合而完成的一项操作。其首先将这个表复制到指定的位置,然后再删除原来的表。也就是说,直到表被完全移到新的数据段中之后,数据库才会删除原来的数据段。所以这个空闲空间一定要保证,否则的话,就可能导致这个作业无法顺利完成。
二是在利用这个语句重新组织表的过程中,原表的ROWID会发生改变。而这个值改变后最大的影响就会使得表中的索引失效。为此在使用这个语句重新组织表之后,就需要对此表重新建立索引。这也就是说,在短时间内用户使用这个表会受到一定的影响。为此在执行这个操作的时候,最好能够选择数据库比较空闲的时候。如果在执行这个语句时能够暂时中断用户的连接,那时最好的。
数据库管理员可以通过数据字典来查询存储空间的碎片状态。如果碎片确实比较多的话,在笔者推荐使用这个语句来重新组织表,以减少碎片空间。如果整个数据库存储空间中都分布着大量的碎片,而不是个别表的问题,那么就需要采用数据泵工具来重新组织全部的表,在最大程度上减少碎片。
- ››oracle 中 UPDATE nowait 的使用方法
- ››Oracle ORA-12560解决方法
- ››Oracle 10g RAC 常用维护命令
- ››Oracle如何在ASM中定位文件的分布
- ››Oracle的DBMS_RANDOM.STRING 的用法
- ››oracle 外部表导入时间日期类型数据,多字段导入
- ››Oracle中查找重复记录
- ››oracle修改用户登录密码
- ››Oracle创建删除用户、角色、表空间、导入导出等命...
- ››Oracle中登陆时报ORA-28000: the account is lock...
- ››Oracle数据库在配置文件中更改最大连接数
- ››Oracle中在pl/sql developer修改表的两种方式
更多精彩
赞助商链接