免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: todayhero
打印 上一主题 下一主题

mysql db_name < db_name.dump如何不覆盖原有数据 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2008-06-15 15:35 |只看该作者
's/insert/replace/g'  ?有点问题

论坛徽章:
0
12 [报告]
发表于 2008-06-17 08:40 |只看该作者
原帖由 yueliangdao0608 于 2008-6-15 13:54 发表



Then he can import from the backup file into a temporary database before processing the data in production environment.


insert ignore就可以保留原有数据啊,何必舍近求远再备份一次呢

论坛徽章:
0
13 [报告]
发表于 2008-06-17 10:12 |只看该作者
这还不好搞?
insert ignore是最方便的了。
如果懒得编辑的话,先吧原来数据用工具比如 phpmyadmin 按 REPLACE 类型导出,然后建个临时库,导入db_name.dump,再运行那些 REPLACE 脚本,最后替换一下库就是了

论坛徽章:
0
14 [报告]
发表于 2008-06-17 12:23 |只看该作者
原帖由 voxxu 于 2008-6-17 08:40 发表


insert ignore就可以保留原有数据啊,何必舍近求远再备份一次呢



前辈指教了。

论坛徽章:
0
15 [报告]
发表于 2008-06-17 13:14 |只看该作者
不过replace into 和 insert ignore 其实是一样的。

论坛徽章:
0
16 [报告]
发表于 2008-06-17 14:10 |只看该作者
原帖由 yueliangdao0608 于 2008-6-17 13:14 发表
不过replace into 和 insert ignore 其实是一样的。



.....一样吗?
INSERT IGNORE 如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,会忽略数据库中已经存在的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳过这条数据。

replace into 如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。

论坛徽章:
0
17 [报告]
发表于 2008-06-17 14:54 |只看该作者
原帖由 voxxu 于 2008-6-17 14:10 发表



.....一样吗?
INSERT IGNORE 如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,会忽略数据库中已经存在的数据,如果数据库没有数据,就插入新的数据,如果有数据的话就跳 ...



你说的相当对

REPLACE is the counterpart to INSERT IGNORE in the treatment of new rows that contain unique key values that duplicate old rows: The new rows are used to replace the old rows rather than being discarded.

论坛徽章:
0
18 [报告]
发表于 2008-08-03 01:21 |只看该作者
路过,学习:)

论坛徽章:
0
19 [报告]
发表于 2008-08-03 08:38 |只看该作者
学习了,高手真多
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP