免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1753 | 回复: 8

[C++] mysql 或者 oracle 存在数据损坏的问题吗 [复制链接]

论坛徽章:
12
2015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之同曦
日期:2017-03-17 19:13:162016科比退役纪念章
日期:2016-11-07 08:28:12luobin
日期:2016-06-17 17:46:36wusuopu
日期:2016-06-17 17:43:4515-16赛季CBA联赛之福建
日期:2016-01-14 12:49:22程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:002015年亚洲杯之科威特
日期:2015-03-24 14:21:272015年迎新春徽章
日期:2015-03-04 09:57:092016科比退役纪念章
日期:2018-04-10 16:20:18
发表于 2017-11-22 08:51 |显示全部楼层
有个问题请教,通用数据库存在数据损坏的情况吗?

比如某一页没写完磁盘,数据库因为某种原因挂了,下次启动因为数据损坏导致数据库启动失败。

有这种情况吗?我是没遇到过。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
发表于 2017-11-22 09:01 |显示全部楼层
本帖最后由 yulihua49 于 2017-11-22 09:03 编辑
VIP_fuck 发表于 2017-11-22 08:51
有个问题请教,通用数据库存在数据损坏的情况吗?

比如某一页没写完磁盘,数据库因为某种原因挂了,下次 ...

有这种情况。工作期间任意断电就可能。
唯一能避免此情况的是INFORMIX数据库,双日志系统。随便什么时候断电都可以,重新开机recover就好了。

论坛徽章:
12
2015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之同曦
日期:2017-03-17 19:13:162016科比退役纪念章
日期:2016-11-07 08:28:12luobin
日期:2016-06-17 17:46:36wusuopu
日期:2016-06-17 17:43:4515-16赛季CBA联赛之福建
日期:2016-01-14 12:49:22程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:002015年亚洲杯之科威特
日期:2015-03-24 14:21:272015年迎新春徽章
日期:2015-03-04 09:57:092016科比退役纪念章
日期:2018-04-10 16:20:18
发表于 2017-11-22 09:05 |显示全部楼层
回复 2# yulihua49

INFORMIX 开源吗

论坛徽章:
0
发表于 2017-11-22 11:20 |显示全部楼层
数据库系统和数据文件是两回事,保存的数据文件出错,或者说磁盘有坏块,跳过去就行了。最多是数据读不出来,但程序本身启动还是正常的。

论坛徽章:
12
2015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之同曦
日期:2017-03-17 19:13:162016科比退役纪念章
日期:2016-11-07 08:28:12luobin
日期:2016-06-17 17:46:36wusuopu
日期:2016-06-17 17:43:4515-16赛季CBA联赛之福建
日期:2016-01-14 12:49:22程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:002015年亚洲杯之科威特
日期:2015-03-24 14:21:272015年迎新春徽章
日期:2015-03-04 09:57:092016科比退役纪念章
日期:2018-04-10 16:20:18
发表于 2017-11-22 11:36 |显示全部楼层
回复 4# sxcong

大牛,好像我的问题不是数据库系统的概念,也不是数据文件的概念啊。
我的问题是数据有损坏的情况。

另外,单纯的跳过去,这不是根本解决办法吧?

拙见。

论坛徽章:
0
发表于 2017-11-22 13:25 |显示全部楼层
你问:“比如某一页没写完磁盘,数据库因为某种原因挂了,下次启动因为数据损坏导致数据库启动失败。”
我说的是下次会启动不会失败的。

至于数据损坏后跳不跳,我刚试了一下:把mysql 数据库的文件手动破坏再启动,启动完全正常。破坏的这个库只有名字,但里面表全空了,没有任何内容。我没看代码,要是有兴趣可以看看代码里是怎么处理的。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
发表于 2017-11-22 15:44 |显示全部楼层
VIP_fuck 发表于 2017-11-22 09:05
回复 2# yulihua49

INFORMIX 开源吗

不开源,归IBM所有。

论坛徽章:
275
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
发表于 2017-11-22 17:28 |显示全部楼层
大型数据库在写磁盘时会考虑没写完就掉电等异常情况的,当然若是物理磁盘损坏导致的问题,那不是软件能解决的

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
发表于 2017-11-22 23:35 |显示全部楼层
本帖最后由 yulihua49 于 2017-11-22 23:46 编辑
hellioncu 发表于 2017-11-22 17:28
大型数据库在写磁盘时会考虑没写完就掉电等异常情况的,当然若是物理磁盘损坏导致的问题,那不是软件能解决 ...

扇区写到一半断电,这个扇区就完了,但非物理损坏。
这种问题,除了INFORMIX,谁也没辙。
他是双日志:物理日志,逻辑日志。
物理日志就是物理扇区影像。要写这个扇区之前,先把这个扇区原先内容搬到物理日志区。然后再写这个扇区。如果搬移时断电,物理日志区为空,对业务无影响。如果写扇区时断电,这个扇区就坏了。重新开机后,数据库会发现有物理日志,把原有扇区覆盖回去,实际上完成了一次rollback。如果写扇区完成,则删除物理日志,完成了commit。当然物理日志与逻辑日志的处理关系较复杂,这里说不清。

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

SACC2019中国系统架构师大会

【数字转型 架构演进】SACC2019中国系统架构师大会,7折限时优惠重磅来袭!
2019年10月31日~11月2日第11届中国系统架构师大会(SACC2019)将在北京隆重召开。四大主线并行的演讲模式,1个主会场、20个技术专场、超千人参与的会议规模,100+来自互联网、金融、制造业、电商等领域的嘉宾阵容,将为广大参会者提供一场最具价值的技术交流盛会。

限时七折期:2019年8月31日前


----------------------------------------

大会官网>>
  

北京盛拓优讯信息技术有限公司. 版权所有 16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122
中国互联网协会会员  联系我们:huangweiwei@it168.com
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP