OCP课程经典案例:利用日志挖掘实现基于SCN的不完全恢复 基于SCN恢复是指当出现用户错误(例如误删除表、误截断表)时,恢复到指定SCN点的恢复。 模拟误删除表t_user。 执行rman,启动数据库到mount状态。 使用setuntil scn命令指定要恢复到的scn点。 转储、恢复数据库,并使用resetlogs选项打开数据库。 --模拟误删除表t_user。 SQL> select count(*) from t_user;???? COUNT(*)???? ----------???? 2 SQL> insert into t_user select 'springmvc_' from dual;???? 1 row created.???? SQL> commit;???? Commit complete.???? SQL> alter system switch logfile;???? System altered.???? SQL> alter system checkpoint;???? System altered.???? SQL> select current_scn fromv$database;???? CURRENT_SCN???? -----------???? 1214281 SQL> drop table t_user;???? Table dropped. 恢复 [oracle@localhost ~]$ rman targetsys/oracle@oralife nocatalog???? RMAN> run {???? 2> startup force mount;???? 3>set until scn=1214281;???? 4> restore database;???? 5> recover database;???? 6> sql 'alter database openresetlogs';???? 7> } 已恢复 SQL>?select count(*) from t_user; COUNT(*)???? ----------???? 3 在实际环境下,应该使用LogMiner确定误操作SCN点。在执行了不完全恢复之后,推荐删除早期所有备份,重新备份数据库。 想要更掌握的更透彻,可以观看我们的免费视频,地址: http://www.chuanke.com/6764109-174690.html https://ke.qq.com/course/134307#term_id=100150389 或者直接到**课堂/传课搜索海文IT教育,观看更多免费视频。 更多精彩课程尽在上海海文信息技术有限公司,http://www.oracleoaec.net/。 |
实现方法:首先自定义一个layout,当用户点击一个可点击的元素时,比如button,我们需要得到用户点击的元素的信息,包含:用户点击了哪个元素、用户点击的那个元素的宽、高、位置信息等。得到了button的信息后,我就可以确定水波纹的范围,然后通过layout进行重绘去绘制水波纹,这样水波纹效果就实现了,当然,这只是大概步骤,中间还是有一些细节需要处理的。 layout的选取:选用LinearLayout 获得用户点击元素:重写layout中的dispatchTouchEvent方法,当用户点击的时候,会有一系列的down、move、up事件,我们要在down的时候来确定事件落在哪个元素上,down的元素就是用户点击的元素,当然为了严谨,我们还要判断up的时候是否也落在同一个元素上面,因为,系统click事件的判断规则就是:down和up同时落在同一个可点击的元素上。 取得被点击元素的信息:被点击元素的信息有:宽、高、left、top、right、bottom 通过layout进行重绘绘制水波纹:用drawCircle绘制一个半透明的圆环即可。 最后延迟up事件的分发。 建议大家观看我们安卓水波纹效果实现的免费视频,更容易理解哦,到**课堂/传课搜索海文IT教育即可观看。 更多安卓课程尽在上海海文信息技术有限公司,http://www.oracleoaec.net/。 |
随着浏览器技术的进步,web前端CSS动画技术已经不是只那些简单的淡入淡出效果或幻灯片效果,它们能做很多更强大的事情。今天,甲骨文OAEC将要教大家用CSS3实现3D翻转特效。 新建只有一个div的页面,给div加上简单的样式 然后在给div加上动画的过渡效果(transition: all 500ms ease;) 加上这个后,所有属性(all)都会有过渡效果,及500ms内,ease的过渡 又因为翻转需要3d效果,所以要加上?transform-style: preserve-3d; preserve-3d的意思是‘子元素将保留其?3D?位置’ 然后利用伪类after,加上翻转的另一面。 现在看到的效果是上下两个div,接下要做的就是让上面那个在初始状态水品翻转90度 transform: rotateX(90deg); 当鼠标移到div上时,触发翻转效果 #d1:hover { ???????? transform: rotateX(-90deg); ???? } 当鼠标触发hover时,会发现翻转有点奇怪,两块div中有很大的空隙 需要加上transform-origin属性 transform-origin是变形原点,也就是该元素围绕着那个点变形或旋转,该属性只有在设置了transform属性的时候起作用 left bottom的意思就是x轴最左,y轴最下 加上之后就能看到正常的翻转了。 懂了吗?不懂的话可以看我们的web前端免费视频课程,地址: http://www.chuanke.com/6764109-178314.html 或者https://ke.qq.com/course/140445#term_id=100158358 也可以到传课和**课堂搜索海文IT教育,观看更多免费视频 更多精彩课程,尽在上海海文信息技术有限公司,http://www.oracleoaec.net/。 |
© 2024 Jinbay.com All rights reserved.
版权所有金海湾。 未经许可,不得转载。