90

是否可以从 --all-databases mysqldump 导入单个数据库?我想我可以手动修改文件,但想知道是否有任何命令行选项可以做到这一点。

我正在移动服务器并且有很多数据库,其中大部分我目前不需要或不想要,但如果需要,我希望可以选择恢复单个数据库。

4

4 回答 4

118

您可以使用以下命令:

mysql -u root -p --one-database destdbname < alldatabases.sql

destdbname您想要恢复的所需数据库在哪里。

恕我直言,另一个更安全的选择是从--all-databases转储中提取数据库。例子:

sed -n '/^-- Current Database: `dbname`/,/^-- Current Database: `/p' alldatabases.sql > output.sql

替换dbname为所需的数据库名称。alldatabases.sql是您的 sql-dump 文件的名称。这样,您将拥有单独的数据库,然后您可以使用简单的 mysql 命令进行恢复。

(致谢:Darren Mothersele - 见他的页面

于 2014-09-22T13:58:13.757 回答
84

mysqldump输出只是一组SQL语句。

您可以在命令行中提供所需的数据库,并使用以下命令跳过针对其他数据库的命令:

mysql -D mydatabase -o mydatabase < dump.sql

这只会mydatabase在使用时执行命令

于 2010-02-26T14:51:02.317 回答
1

使用sedHetzbh 建议的方法时,请务必从原始转储中手动复制初始行和最终行,例如

/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8mb4 */;
/*!40103 SET @OLD_TIME_ZONE=@@TIME_ZONE */;
/*!40103 SET TIME_ZONE='+00:00' */;
/*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;

/*!40103 SET TIME_ZONE=@OLD_TIME_ZONE */;

/*!40101 SET SQL_MODE=@OLD_SQL_MODE */;
/*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;
/*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;
/*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;

分别到 sed 生成的剥离文件的开头和结尾。否则,由于转储中表的字母顺序(即)不遵守外部约束,导入可能会失败errno: 150 "Foreign key constraint is incorrectly formed"

于 2020-12-03T13:45:04.283 回答
0

这是仅恢复$DB_FROM$BACKUP_FILE备份文件命名的数据库的命令:

(sed '/^-- Current Database: `/q' "$BACKUP_FILE"; sed -n "/^-- Current Database: \`$DB_FROM\`/,/^-- Current Database: \`/p" "$BACKUP_FILE") | mysql -u root -p

如果您希望同时将新数据库恢复为$DB_TO(而不是$DB_FROM),这意味着将数据库恢复为不同的名称,这里是完整的命令:

(sed '/^-- Current Database: `/q' "$BACKUP_FILE"; sed -n "/^-- Current Database: \`$DB_FROM\`/,/^-- Current Database: \`/p" "$BACKUP_FILE") | sed "s/\`$DB_FROM\`/\`$DB_TO\`/g" | mysql -u root -p

我的回答受到了这个以及这个这个网页的启发。

于 2021-09-28T16:10:43.243 回答