我一直在遇到没有创建数据库的问题。
我这样修好了
mysql -u root -e "CREATE DATABASE db_name" mysql db_name --force < import_script.sql
在命令行上提供凭据不是一个好主意。上面的答案很棒,但忽略了
mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql
etc / myhost.cnf是包含主机,用户,密码的文件,并且您避免在命令行上显示密码。这是一个样本,
[client] host=hostname.domainname user=dbusername password=dbpassword
虽然这里的大多数答案都提到了简单的命令
mysql -u database_user -p [db_name]&lt; database_file.sql来
今天,数据库和表格的utf8-collation很常见,而这个命令还不够。 在导出的表中使用utf8-collation,需要使用此命令:
的 mysql -u database_user -p --default-character-set = utf8 [db_name]&lt; database_file.sql来 强>
Surley这也适用于其他charsets,如何显示正确的符号可以在这里看到:
https://dev.mysql.com/doc/refman/5.7/en/show-collation.html
一条评论还提到,如果数据库永远不存在,则必须首先创建一个空数据库。在某些情况下,这可能是正确的,但取决于导出文件。如果导出的文件已包含用于创建数据库的命令,则永远不必在分离的步骤中创建数据库,这甚至可能导致导入时出错。所以在导入时,建议首先查看文件中的内容以了解哪些命令包含在那里,在导出时建议注意设置,特别是如果文件非常大且难以在编辑器中读取。
此命令还有更多参数列出和解释:
https://dev.mysql.com/doc/refman/5.7/en/mysql-command-options.html
如果您使用其他数据库版本,请考虑搜索相应的手册版本。上面提到的链接指的是MySQL 5.7版。
关于导入大文件所花费的时间:最重要的是,由于MySQL的默认设置,它需要更多时间 autocommit = true 。您必须在导入文件之前将其设置为关闭,然后检查导入如何像gem一样工作。
autocommit = true
你只需要做以下事情:
mysql> use db_name; mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;
在所有答案中,对于上述问题,这是最好的答案:
mysql> use db_name; mysql> source file_name.sql;
常用的 mysqldump的 用于备份整个数据库:
shell> mysqldump db_name > backup-file.sql
您可以将转储文件加载回服务器,如下所示:
的 UNIX 强>
shell> mysql db_name < backup-file.sql
同样的 的 视窗 强> 命令提示符:
mysql -p -u [user] [database] < backup-file.sql
的 电源外壳 强>
C:\> cmd.exe /c "mysql -u root -p db_name < backup-file.sql"
的 MySQL命令行 强>
mysql> use db_name; mysql> source backup-file.sql;
mysql --user=[user] --password=[password] [database] < news_ml_all.sql
要导入单个数据库,请使用以下命令。
mysql -u username -p password dbname < dump.sql
要导入多个数据库转储,请使用以下命令。
mysql -u username -p password < dump.sql
要将数据库转储到SQL文件,请使用以下命令
mysqldump -u username -p database_name > database_name.sql
将SQL文件导入数据库(确保您与SQL文件位于同一目录中或提供文件的完整路径)
mysql -u username -p database_name < database_name.sql
对于我只有默认root + withoutpassword的信息,它不适用于所有上述答案。
我创建了一个具有所有权限和密码的新用户。有用。
-apassword没有空间。
以下步骤有助于上传 file.sql 到MySQL数据库。
file.sql
第1步:上传 file.sql.zip 到任何目录并在那里解压缩 的 注意 强> : sudo apt-get install unzip : sudo apt-get unzip file.sql.zip 第2步:现在导航到该目录。例: cd /var/www/html
file.sql.zip
sudo apt-get install unzip
sudo apt-get unzip file.sql.zip
cd /var/www/html
第3步: mysql -u username -p database-name < file.sql 输入密码并等待上传完成。
mysql -u username -p database-name < file.sql
最简单的导入到您的架构的方法:
登录mysql并发出下面提到的命令。
mysql> use your_db_name; mysql> source /opt/file.sql;
我正在使用带有Powershell 5的Windows 10,我发现几乎所有“unix-like”解决方案都不适用于我。
> mysql -u[username] [database-name] < my-database.sql At line:1 char:31 + mysql -u[username] [database-name] < my-database.sql + ~ The '<' operator is reserved for future use. + CategoryInfo : ParserError: (:) [], ParentContainsErrorRecordException + FullyQualifiedErrorId : RedirectionNotSupported
我最终使用这个命令。
> type my-database.sql | mysql -u[username] -h[localhost] -p [database-name]
它完美无缺,希望它有所帮助。
谢谢 @ 弗朗切斯科卡苏拉 的 回答 顺便说一句。
如果您已经拥有数据库,请使用以下内容导入 dump 或者 sql 文件
dump
sql
mysql -u username -p database_name < file.sql
如果你不需要在MySQL中创建相关数据库(空),那么首先登录到 MySQL 通过在终端或cmd中运行以下命令来控制台
MySQL
mysql -u userName -p;
并在提示时提供密码。
接下来创建一个数据库并使用它
mysql>create database yourDatabaseName; mysql>use yourDatabaseName;
然后导入 sql 或者 dump 从中提交数据库
mysql> source pathToYourSQLFile;
注意:如果您的终端不在的位置 dump 要么 sql 文件存在,使用上面的相对路径。
mysql -u root -p password -D database_name << import.sql
使用mysql帮助获取详细信息 mysql --help
mysql --help
我认为这些在我们的背景下将是有用的选择
[~]$ mysql --help mysql Ver 14.14 Distrib 5.7.20, for osx10.12 (x86_64) using EditLine wrapper Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved. Usage: mysql [OPTIONS] [database] -?, --help Display this help and exit. -I, --help Synonym for -? --bind-address=name IP address to bind to. -D, --database=name Database to use. --delimiter=name Delimiter to be used. --default-character-set=name Set the default character set. -f, --force Continue even if we get an SQL error. -p, --password[=name] Password to use when connecting to server. -h, --host=name Connect to host. -P, --port=# Port number to use for connection or 0 for default to, in order of preference, my.cnf, $MYSQL_TCP_PORT, /etc/services, built-in default (3306). --protocol=name The protocol to use for connection (tcp, socket, pipe, -s, --silent Be more silent. Print results with a tab as separator, each row on new line. -v, --verbose Write more. (-v -v -v gives the table output format). -V, --version Output version information and exit. -w, --wait Wait and retry if connection is down.
有趣的是,如果我们要导入一个大型数据库而没有进度条。使用Pipe Viewer查看通过管道传输的数据
对于Mac, brew install pv 。对于Debian / Ubuntu, apt-get install pv 。 其他人,请参阅 http://www.ivarch.com/programs/pv.shtml
brew install pv
apt-get install pv
pv import.sql | mysql -u root -p password -D database_name 1.45GiB 1:50:07 [339.0KiB/s] [=============> ] 14% ETA 11:09:36 1.46GiB 1:50:14 [ 246KiB/s] [=============> ] 14% ETA 11:09:15 1.47GiB 1:53:00 [ 385KiB/s] [=============> ] 14% ETA 11:05:36