Chinaunix

标题: mysql db_name < db_name.dump如何不覆盖原有数据 [打印本页]

作者: todayhero    时间: 2008-06-04 21:01
标题: mysql db_name < db_name.dump如何不覆盖原有数据
mysql db_name < db_name.dump如何不覆盖原有数据




情况是这样的.
我要导入db_name.dump(这个部分中部分内容到db_name库已经存在了)数据内容到db_name库中,这样直接导入会覆盖原有的数据.如何不覆盖呢?
作者: 75252    时间: 2008-06-05 17:01
标题: 回复 #1 todayhero 的帖子
vi db_name.dump
作者: todayhero    时间: 2008-06-05 17:07
原帖由 75252 于 2008-6-5 17:01 发表
vi db_name.dump



你不会是说编辑db_name.dump,将重复的内容通过脚本删除吧!这就太麻烦了.
作者: voxxu    时间: 2008-06-05 17:11
sed dump文件,把所以的INSERT替换成INSERT IGNORE
作者: 75252    时间: 2008-06-05 17:21
原帖由 voxxu 于 2008-6-5 17:11 发表
sed dump文件,把所以的INSERT替换成INSERT IGNORE

  

正解!我可能会选择这么搞嘿嘿!不知道有没有高人
作者: 爱佟儿    时间: 2008-06-06 17:59
sed -i 's/insert/replace/g' db_name.dump | mysql db_name
作者: yueliangdao0608    时间: 2008-06-06 18:15
原帖由 爱佟儿 于 2008-6-6 17:59 发表
sed -i 's/insert/replace/g' db_name.dump | mysql db_name



Good!
作者: todayhero    时间: 2008-06-10 21:52
原帖由 爱佟儿 于 2008-6-6 17:59 发表
sed -i 's/insert/replace/g' db_name.dump | mysql db_name


THX
作者: voxxu    时间: 2008-06-14 17:24
原帖由 爱佟儿 于 2008-6-6 17:59 发表
sed -i 's/insert/replace/g' db_name.dump | mysql db_name



楼主是要保留原有记录,你都replace掉了和覆盖有啥区别呀,还不如直接覆盖呢。
作者: yueliangdao0608    时间: 2008-06-15 13:54
原帖由 voxxu 于 2008-6-14 17:24 发表



楼主是要保留原有记录,你都replace掉了和覆盖有啥区别呀,还不如直接覆盖呢。



Then he can import from the backup file into a temporary database before processing the data in production environment.
作者: phphp    时间: 2008-06-15 15:35
's/insert/replace/g'  ?有点问题
作者: voxxu    时间: 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就可以保留原有数据啊,何必舍近求远再备份一次呢
作者: sunnyfun    时间: 2008-06-17 10:12
这还不好搞?
insert ignore是最方便的了。
如果懒得编辑的话,先吧原来数据用工具比如 phpmyadmin 按 REPLACE 类型导出,然后建个临时库,导入db_name.dump,再运行那些 REPLACE 脚本,最后替换一下库就是了
作者: yueliangdao0608    时间: 2008-06-17 12:23
原帖由 voxxu 于 2008-6-17 08:40 发表


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



前辈指教了。
作者: yueliangdao0608    时间: 2008-06-17 13:14
不过replace into 和 insert ignore 其实是一样的。
作者: voxxu    时间: 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索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
作者: yueliangdao0608    时间: 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.
作者: gogo407    时间: 2008-08-03 01:21
路过,学习:)
作者: yxyup    时间: 2008-08-03 08:38
学习了,高手真多




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2