【翻译自mos文章】OGG Director 不会purge log table

本文讨论了在使用Oracle GoldenGate时遇到的OGGDirector未清除日志表的问题,通过调整配置参数、操作数据库表以及重启服务等步骤来解决此问题。文章详细解释了症状、原因及解决方案,旨在帮助用户理解和解决类似问题。

OGG Director 不会purge log table。

来源于:OGG Director does not Purge Log Table (文档 ID 1637931.1)

适用于:
Management Pack for Oracle GoldenGate - Version 12.1.2.0.1 and later
Information in this document applies to any platform.

症状:
Purge rule 被设置为1 小时的默认值,但是purge table 并没有发生。

SQL>select to_char(min(sourcetimestamp),'yyyy-mm-dd hh24:mi:ss') from gguser.logentryb;

TO_CHAR(MIN(SOURCET
-------------------
2012-05-29 19:33:43   ------------------>>>>>此时间是ogg的部署时间(不是ogg director的部署时间)

SQL>select to_char(min(inserttimestamp),'yyyy-mm-dd hh24:mi:ss') from gguser.logentryb;

TO_CHAR(MIN(SOURCET
-------------------
2014-02-26 23:04:09   ------------------>>>>>此时间是ogg director的部署时间(不是ogg的部署时间)

SQL>select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

TO_CHAR(SYSDATE,'YY
-------------------
2014-03-14 13:48:06   ------------------>>>>>此时间是ogg director所在的os的时间。


原因:

在Admin tool 中,"Log Purge Hours" 被设置为72小时,我们怀疑有些 repository  tables 有corrupted row,或者他们太多的行。

解决方案:

1. Logon to the Director Admin Tool, click on the Monitor Agent tab. Make sure value of Go Back Hours is 0, the default.
2. Logon to the Director Admin Tool, click on the Monitor Agent tab. The default for "Log Purge Hours" is 72 hours. Please
reduce it to your interested retention period
3. Stop the Director server
4. On the OGG instances being monitored

os> cd 
os> cp ggserr.log ggserr.log.bak
os> cat /dev/null > ggserr.log

5. truncate the logentryb, statentryb tables directly from the DB. If needed you could take a export dump before truncating
6. Restart Director server

 

【电动汽车充电站有序充电调度的分散式优化】基于蒙特卡诺和拉格朗日的电动汽车优化调度(分时电价调度)(Matlab代码实现)内容概要:本文介绍了基于蒙特卡洛和拉格朗日方法的电动汽车充电站有序充电调度优化方案,重点在于采用分散式优化策略应对分时电价机制下的充电需求管理。通过构建数学模型,结合不确定性因素如用户充电行为和电网负荷波动,利用蒙特卡洛模拟生成大量场景,并运用拉格朗日松弛法对复杂问题进行分解求解,从而实现全局最优或近似最优的充电调度计划。该方法有效降低了电网峰值负荷压力,提升了充电站运营效率与经济效益,同时兼顾用户充电便利性。 适合人群:具备一定电力系统、优化算法和Matlab编程基础的高校研究生、科研人员及从事智能电网、电动汽车相关领域的工程技术人员。 使用场景及目标:①应用于电动汽车充电站的日常运营管理,优化充电负荷分布;②服务于城市智能交通系统规划,提升电网与交通系统的协同水平;③作为学术研究案例,用于验证分散式优化算法在复杂能源系统中的有效性。 阅读建议:建议读者结合Matlab代码实现部分,深入理解蒙特卡洛模拟与拉格朗日松弛法的具体实施步骤,重点关注场景生成、约束处理与迭代收敛过程,以便在实际项目中灵活应用与改进。
### 删除表结构和数据的 SQL 语句 在 SQL 中,`DROP TABLE` 语句用于删除整个表及其结构,包括表中的所有数据、索引和约束。如果需要彻底删除表而不将其放入回收站(Recycle Bin),可以使用 `PURGE` 参数,这样可以确保数据不会被恢复[^3]。 基本语法如下: ```sql DROP TABLE table_name PURGE; ``` 此语句会立即删除指定的表,并跳过回收站,防止后续通过 Flashback Drop 恢复表数据[^3]。在某些数据库系统中,如 Oracle,`PURGE` 是一个关键参数,用于控制是否将删除的对象放入回收站。 如果数据库不支持 `PURGE` 参数(如 PostgreSQL 或 MySQL),则可以直接使用 `DROP TABLE`,它默认不会将表放入回收站: ```sql DROP TABLE table_name; ``` 此外,`DROP TABLE` 语句具有破坏性,执行后将无法恢复表结构和数据,因此在执行前应确保已做好数据备份或确认删除操作是必要的[^2]。 如果表之间存在外键约束,应先删除引用表(即依赖该表的其他表),否则可能会导致错误。例如: ```sql DROP TABLE Employee1, Department; ``` 此语句会先删除 `Employee1` 表和 `Department` 表之间的依赖关系,然后删除这两个表[^1]。 需要注意的是,删除表后,所有与该表相关的索引、触发器、存储过程和函数可能会失效,必须进行相应的维护或调整。 --- ### 示例:彻底删除表结构和数据 以下是一个使用 `DROP TABLE ... PURGE` 彻底删除表的示例: ```sql DROP TABLE employees PURGE; ``` 此语句将删除名为 `employees` 的表,并跳过回收站,防止通过 Flashback Drop 恢复该表[^3]。 --- ### 权限要求 只有表的所有者、被授予 `DROP` 权限的用户,或拥有 `DROP ANY TABLE` 权限的用户才能执行 `DROP TABLE` 操作。系统管理员通常默认拥有该权限[^2]。 --- ### 注意事项 - 使用 `DROP TABLE ... PURGE` 会立即删除表及其所有相关对象,无法通过回收站恢复。 - 如果删除的是分区表,则会同时删除该表的所有分区。 - 在执行 `DROP TABLE` 之前,应确保没有其他对象(如视图、存储过程)依赖该表,否则可能导致这些对象失效。 --- ### 相关问题 1. DROP TABLE 和 TRUNCATE 在删除数据时有何区别? 2. 如何恢复被 DROP TABLE 删除的表(如果未使用 PURGE)? 3. 使用 PURGE 参数删除表后,是否还能通过数据库备份恢复数据? 4. DROP TABLE 操作对索引和依赖对象有何影响? 5. 如何查看哪些表可以被安全删除而不影响其他数据库对象?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值