首页
网页制作
网络编程
脚本专栏
数据库
网站运营
网络安全
平面设计
CMS教程
搜索
建站极客
数据库
oracle
正文
DBA_2PC_PENDING 介绍
所属分类:
数据库
/
oracle
阅读数: 136
收藏 0
赞 0
分享
DBA_2PC_PENDING
Oracle会自动处理分布事务,保证分布事务的一致性,所有站点全部提交或全部回滚。一般情况下,处理过程在很短的时间内完成,根本无法察觉到。但是,如果在commit或rollback的时候,出现了连接中断或某个数据库站点CRASH的情况,则提交操作可能会无法继续,此时DBA_2PC_PENDING和DBA_2PC_NEIGHBORS中会包含尚未解决的分布事务。
对于绝大多数情况,当恢复连接或CRASH的数据库重新启动后,会自动解决分布式事务,不需要人工干预。只有分布事务锁住的对象急需被访问,锁住的回滚段阻止了其他事务的使用,网络故障或CRASH的数据库的恢复需要很长的时间等情况出现时,才使用人工操作的方式来维护分布式事务。
手工强制提交或回滚将失去二层提交的特性,Oracle无法继续保证事务的一致性,事务的一致性应由手工操作者保证。
对于分布式事务,给事务命名是一个好的习惯。而且在事务执行过程中,可以使用ALTER SESSION ADVISE COMMIT(ROLLBACK);语句,为手工解决分布事务提供参考信息。
当手工解决分布事务出现了冲突,比如一个站点进行了提交而另一个进行了ROLLBACK,这时,DBA_2PC_PENDING中的记录不会清除,必须使用DBMS_TRANSACTION.PURGE_MIXED过程来清除。
如果CRASH的数据库必须重建,或者无法再次启动,则DBA_2PC_PENDING中的记录也无法自动清除,需要使用DBMS_TRANSACTION.PURGE_LOST_DB_ENTRY过程来清除。
Oracle9i中,当使用上述两个过程时,必须处于UNDO_MANAGEMENT=MANUAL的模式,这个限制条件Oracle没有写到文档中。一般使用9i都会使用AUTO模式(Oracle也是这样推荐的),也就是说,想要清除DBA_2PC_PENDING中的信息,必须重起数据库两次,感觉这两个过程的实际用处不大。
出现无法解决的分布式事务时,可能会锁住分布式事务中涉及的表,由于Oracle无法确定哪些数据是提交过的,哪些是没有提交的,无法确定查询操作可见的结果集,因此,即使是查询操作也无法在该表上执行。
使用ALTER SYSTEM DISABLE DISTRIBUTED RECOVERY,可以使Oracle不再自动解决分布事务,即使网络恢复连接或者CRASH的数据库重新启动。ALTER SYSTEM ENABLE DISTRIBUTED RECOVERY恢复自动解决分布事务。
为了保证数据库之间的SCN同步,可以采用两种方法:在查询数据前,执行SELECT * FROM DUAL@REMOTE或者在执行查询前提交或回滚当前事务。
更多精彩内容
其他人还在看
oracle(plsql)生成流水号
这篇文章主要介绍了oracle(plsql)生成流水号,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
oracle中decode函数的使用方法
这篇文章主要介绍了oracle中decode函数的使用方法,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
Oracle数据远程连接的四种设置方法和注意事项
Oracle数据库的远程连接可以通过多种方式来实现,本文我们主要介绍四种远程连接的方法和注意事项,并通过示例来说明,接下来我们就开始介绍
评论 0
收藏 0
赞 0
分享
oracle表空间中空表统计方法示例介绍
这篇文章主要介绍了oracle表空间中空表统计方法,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
oracle用户权限、角色管理详解
这篇文章主要介绍了oracle用户权限、角色管理的使用和示例,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
oracle用户权限管理使用详解
这篇文章主要介绍了oracle用户权限管理使用方法,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
oracle生成动态前缀且自增号码的函数分享
这篇文章主要介绍了oracle生成动态前缀且自增号码的函数,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
45个非常有用的 Oracle 查询语句小结
这里我们介绍的是 40+ 个非常有用的 Oracle 查询语句,主要涵盖了日期操作,获取服务器信息,获取执行状态,计算数据库大小等等方面的查询。这些是所有 Oracle 开发者都必备的技能,所以快快收藏吧
评论 0
收藏 0
赞 0
分享
oracle监控某表变动触发器例子(监控增,删,改)
这篇文章主要介绍了oracle监控某表变动触发器例子(监控增,删,改),用于监控某表的变动并生成日志记录到另一个表,需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
oracle 数据库隔离级别学习
这篇文章主要介绍了oracle数据库的隔离级别相关的知识,数据库操作的隔离级别,有需要的朋友可以参考下
评论 0
收藏 0
赞 0
分享
查看更多
网络赚钱
更多
又被电商耍?2015.6·18年中大促"先涨后降"把戏仍在
调查:55.2%受访用户不会相信朋友圈打广告的化妆品
网赚之谈:做什么网站才能让我们草根站长有个出路
adsense西联邮局收款两张版本单子填写示例
网站赚钱就靠广告到底行不行?
如何通过网络赚钱?互联网广告模式你知道多少
站长故事
更多
从地图到苹果6!盘点苹果产品的四大败笔
一个大学生自述:我是如何把公司做死的
一成不变的站长到底还能活多久?
站长故事之我的个人站长之路
做站7年
人物:戴志康,80后创业者携惊叹号而来