dba_tables的last_ddl_time列

    在dba_objects里面有一列last_ddl_time,之前一直有个误解,认为只有当table的表结构发生了改变之后,
才会修改该列的值。其实是只要对table进行了DDL操作,就会修改last_ddl_time的值。
    DDL操作除了常见的对表结构的更改,还有truncate,grant等操作。都会修改last_ddl_time的值。
以grant为例:
--进行grant操作之前
SQL> select to_char(last_ddl_time,'yyyymmdd hh:mi:ss')  from dba_objects where o
bject_name='EMP';

TO_CHAR(LAST_DDL_
-----------------
20050830 03:06:10

--进行grant操作
SQL> grant select on scott.emp to rman817;

授权成功。

--再查看last_ddl_time的值
SQL> select to_char(last_ddl_time,'yyyymmdd hh:mi:ss')  from dba_objects where o
bject_name='EMP';

TO_CHAR(LAST_DDL_
-----------------
20091113 11:04:22

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/21805468/viewspace-619627/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/21805468/viewspace-619627/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: dbms_metadata.get_ddl是一个Oracle数据库中的函数,用于获取指定对象的DDL(数据定义语言)。该函数可以用于获取表、视图、索引、约束、序、存储过程等对象的DDL语句。使用该函数可以方便地将数据库对象的定义导出到脚本文件中,以便于备份、迁移、升级等操作。 ### 回答2: DBMS_METADATA.GET_DDL是一种在Oracle数据库中获取DDL(数据定义语言)的函数。DDL是一个数据库对象的定义,由注意事项和指令组成。DDL包括创建、修改和删除数据库的对象,例如表、视图、过程、约束等。 DBMS_METADATA.GET_DDL函数可以获取数据库对象的DDL语句,包括表、索引、序、视图、存储过程等多种类型的对象。这个函数使用了Oracle内置的元数据接口,可以提供各种数据库对象的DDL语句,从而方便用户快速了解数据库结构。 当我们需要将数据库特定对象的定义从一个环境传递到另一个环境时,我们可以使用DBMS_METADATA.GET_DDL函数。例如,我们可以将表格、视图、过程和其他对象的DDL语句等通过此函数获得,然后将这些语句放在脚本或文件中,以进行备份、同步、升级或下一步操作。 此外,DBMS_METADATA.GET_DDL函数可以用于在Oracle数据库中查看DDL语句,以便更好地理解和分析数据库结构。使用该函数,可以快速获取库表对象的DDL语句,而无需浏览数据库中自动产生的DDL语句。同时,DBMS_METADATA.GET_DDL函数可以输出不同格式的DDL语句,包括简约格式、标准格式、XML格式和JSON格式等。 总之,DBMS_METADATA.GET_DDL函数为Oracle数据库提供了一种用户友好的方式来获取DDL语句。它可以方便地获取数据库对象的DDL语句,从而优化数据库管理和分析流程。 ### 回答3: dbms_metadata.get_ddl是一种Oracle数据库的元数据提取函数,它可以获取对象的SQL定义,包括表、索引、用户、触发器、存储过程等。这个函数有很多的应用场景,其中最常见的用途是进行数据库对象的备份和还原,以及进行数据库对象的比较和升级。 使用dbms_metadata.get_ddl函数,我们可以轻松地获取指定对象的DDL定义,例如: SELECT dbms_metadata.get_ddl('TABLE', 'MY_TABLE') FROM dual; 这个语句可以获取名为MY_TABLE的表的创建语句。同样,我们也可以通过指定不同的对象类型来获取相应的DDL定义,例如: SELECT dbms_metadata.get_ddl('INDEX', 'MY_INDEX') FROM dual; 这个语句可以获取名为MY_INDEX的索引的创建语句。 除了获取单个对象的DDL定义外,dbms_metadata.get_ddl函数还支持获取多个对象的DDL定义,例如: SELECT dbms_metadata.get_ddl('TABLE', t.table_name) FROM user_tables t; 这个语句可以获取当前用户下所有表的DDL定义。 需要注意的是,dbms_metadata.get_ddl函数有一定的局限性,它只能获取Oracle数据库内部定义的DDL语句,不支持获取用户自定义的DDL语句。此外,该函数也不能获取对象的数据内容,仅能获取对象的结构定义。 总之,dbms_metadata.get_ddl函数是非常实用的元数据提取函数,它可以方便地获取Oracle数据库对象的DDL定义。在进行数据库备份、还原、比较和升级时,使用该函数可以节省大量时间和精力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值