我有一个.sql
文件,其导出来自phpMyAdmin
。我想使用命令行将其导入另一台服务器。
我安装了Windows Server 2008 R2。我将.sql
文件放在 C驱动器 上,然后我尝试了这个命令
database_name < file.sql
无效我收到语法错误。
答案 0 :(得分:3139)
尝试:
mysql -u username -p database_name < file.sql
注1:最好使用SQL文件file.sql
的完整路径。
注2:使用-R
和--triggers
来保留原始数据库的例程和触发器。默认情况下不会复制它们。
Note-3 如果mysql已经存在并且导出的SQL不包含CREATE DATABASE
(用{{}导出,则可能必须从mysql创建(空)数据库。 1}}或--no-create-db
选项),然后才能导入它。
答案 1 :(得分:652)
mysqldump的一个常见用途是备份整个数据库:
shell> mysqldump db_name > backup-file.sql
您可以将转储文件加载回服务器,如下所示:
<强> UNIX 强>
shell> mysql db_name < backup-file.sql
Windows 命令提示符中的相同内容:
mysql -p -u [user] [database] < backup-file.sql
<强>的PowerShell 强>
C:\> cmd.exe /c "mysql -u root -p db_name < backup-file.sql"
MySQL命令行
mysql> use db_name;
mysql> source backup-file.sql;
答案 2 :(得分:269)
关于导入大文件所花费的时间:最重要的是,由于MySQL的默认设置为autocommit = true
,因此需要更多时间。您必须在导入文件之前将其设置为off,然后检查导入如何像gem一样工作。
你只需要做以下事情:
mysql> use db_name;
mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;
答案 3 :(得分:101)
在所有答案中,对于上述问题,这是最好的答案:
mysql> use db_name;
mysql> source file_name.sql;
答案 4 :(得分:65)
我们可以使用此命令从命令行导入SQL:
mysql -u username -p password db_name < file.sql
例如,如果用户名为root
且密码为password
。并且您的数据库名称为bank
,SQL文件为bank.sql
。然后,只需这样做:
mysql -u root -p password bank < bank.sql
记住您的SQL文件所在的位置。如果您的SQL文件位于Desktop
文件夹/目录中,请转到桌面目录并输入如下命令:
~ ? cd Desktop
~/Desktop ? mysql -u root -p password bank < bank.sql
如果您位于Project
目录中,并且您的SQL文件位于Desktop
目录中。如果您想从Project
目录访问它,那么您可以这样做:
~/Project ? mysql -u root -p password bank < ~/Desktop/bank.sql
答案 5 :(得分:48)
如果您已有数据库,请使用以下内容导入dump
或sql
文件
mysql -u username -p database_name < file.sql
如果您不需要在MySQL中创建相关数据库(空),首先登录到MySQL
控制台,方法是在终端或cmd中运行以下命令
mysql -u userName -p;
并在提示时提供密码。
接下来创建一个数据库并使用它
mysql>create database yourDatabaseName;
mysql>use yourDatabaseName;
然后从{/ p>将sql
或dump
文件导入数据库
mysql> source pathToYourSQLFile;
注意:如果您的终端不在dump
或sql
文件所在的位置,请使用上面的相对路径。
答案 6 :(得分:44)
对我有用的解决方案如下:
Use your_database_name;
SOURCE path_to_db_sql_file_on_your_local;
答案 7 :(得分:34)
转到您拥有MySQL可执行文件的目录。 -u
代表用户名,-p
提示输入密码:
C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql
答案 8 :(得分:27)
要将数据库转储到SQL文件,请使用以下命令
mysqldump -u username -p database_name > database_name.sql
将SQL文件导入数据库(确保您与SQL文件位于同一目录中或提供文件的完整路径)
mysql -u username -p database_name < database_name.sql
答案 9 :(得分:26)
我认为值得一提的是,您还可以使用zcat
加载 gzipped(压缩)文件,如下所示:
zcat database_file.sql.gz | mysql -u username -p -h localhost database_name
答案 10 :(得分:26)
要导入单个数据库,请使用以下命令。
mysql -u username -p password dbname < dump.sql
要导入多个数据库转储,请使用以下命令。
mysql -u username -p password < dump.sql
答案 11 :(得分:25)
最简单的导入架构的方法:
登录mysql并发出以下提及的命令。
mysql> use your_db_name;
mysql> source /opt/file.sql;
答案 12 :(得分:19)
对于导出数据库:
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
databaseReference.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange( DataSnapshot dataSnapshot) {
Glide.with(get Context()).load(dataSnapshot.get Value(String.class)).into(profImage);
}
@Override
public void onCancelled(DatabaseError databaseError){
}
});
}
对于导入数据库:
mysqldump -u username -p database_name > file.sql
答案 13 :(得分:17)
mysql --user=[user] --password=[password] [database] < news_ml_all.sql
答案 14 :(得分:14)
要一次导入多个SQL文件,请使用:
(\\d+)(?:\\.(\\d+)){0,2}(?:\\.)?$
简单导入:
# Unix-based solution
for i in *.sql;do mysql -u root -pPassword DataBase < $i;done
WAMP:
# Unix-based solution
mysql -u root -pPassword DataBase < data.sql
对于XAMPP:
#mysqlVersion replace with your own version
C:\wamp\bin\mysql\mysqlVersion\bin\mysql.exe -u root -pPassword DataBase < data.sql
答案 15 :(得分:12)
如果.sql文件包含CREATE DATABASE IF NOT EXISTS db_name
和USE db_name
语句,则无需在命令行中指定数据库的名称。
如果.sql文件中提到的数据库不存在,请确保您与具有创建数据库权限的用户进行连接。
答案 16 :(得分:11)
转到开车:
command: d:
MySQL登录
command: c:\xampp\mysql\bin\mysql -u root -p
它会要求pwd。输入它:
pwd
选择数据库
use DbName;
提供文件名
\.DbName.sql
答案 17 :(得分:9)
mysql -u username -p database_name --force < file.sql
答案 18 :(得分:8)
转到您拥有MySQL的目录。
c:\mysql\bin\> mysql -u username -p password database_name <
filename.sql
同样要转储所有数据库,请使用-all-databases
选项,不再需要指定数据库名称。
mysqldump -u username -ppassword –all-databases > dump.sql
或者您可以使用像SQLyog这样的GUI客户端来执行此操作。
答案 19 :(得分:8)
mysql -u root -p password -D database_name << import.sql
使用mysql帮助获取详细信息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
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
答案 20 :(得分:7)
以下命令适用于命令行(cmd)on {7}上的Windows 7。
d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe -u root -p db_name < database.sql
答案 21 :(得分:7)
我认为这对使用Mac OS X的人有用:
/Applications/xampp/xamppfiles/bin/mysql -u root -p database < database.sql
将xampp
替换为mamp
或其他网络服务器。
答案 22 :(得分:7)
虽然这里的大多数答案都提到了简单的命令
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/mysql-command-options.html
如果您使用其他数据库版本,请考虑搜索相应的手册版本。上述链接指的是MySQL 5.7版。
答案 23 :(得分:6)
您可以尝试此查询。
导出:
mysqldump -u username –-password=your_password database_name > file.sql
导入:
mysql -u username –-password=your_password database_name < file.sql
并在此链接后详细说明:
答案 24 :(得分:5)
我一直在遇到没有创建数据库的问题。
我像这样修理了
/dev/null
答案 25 :(得分:5)
出于备份目的,制作BAT文件并使用Task Scheduler运行此BAT文件。它将需要备份数据库;只需复制以下行并粘贴到Notepad中,然后保存.bat文件,并在您的系统上运行它。
@echo off
for /f "tokens=1" %%i in ('date /t') do set DATE_DOW=%%i
for /f "tokens=2" %%i in ('date /t') do set DATE_DAY=%%i
for /f %%i in ('echo %date_day:/=-%') do set DATE_DAY=%%i
for /f %%i in ('time /t') do set DATE_TIME=%%i
for /f %%i in ('echo %date_time::=-%') do set DATE_TIME=%%i
"C:\Program Files\MySQL\mysql server 5.5\bin\mysqldump" -u username -ppassword mysql>C:/%DATE_DAY%_%DATE_TIME%_database.sql
答案 26 :(得分:5)
有时,定义的端口以及该数据库的服务器IP address也很重要......
mysql -u user -p user -h <Server IP> -P<port> (DBNAME) < DB.sql
答案 27 :(得分:5)
在命令行上提供凭据不是一个好主意。上面的答案很棒,但忽略了提及
mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql
其中etc / myhost.cnf是包含主机,用户,密码的文件,并且您避免在命令行上显示密码。这是一个样本,
[client]
host=hostname.domainname
user=dbusername
password=dbpassword
答案 28 :(得分:4)
简单的解决方案:从终端访问mysql,然后....
1) Database selection
mysql> use database_name;
2) Importing execution
mysql> source exported_file.sql;
example : mysql> source /var/www/html/db/my_database.sql;
答案 29 :(得分:4)
我使用Windows 10和Powershell 5,我发现几乎所有&#34; unix-like&#34;解决方案对我不起作用。
> 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]
它完美无缺,希望它有所帮助。
感谢@ Francesco Casula&#39; s answer btw。
答案 30 :(得分:4)
与https://stackoverflow.com/a/17666285/1888983类似 我的主要区别是:
INDEX
和密码-p
使用MariaDB运行fedora 26。
答案 31 :(得分:4)
有关我只有默认root + withoutpassword的信息,它不适用于以上所有答案。
我创建了一个拥有所有权限和密码的新用户。有用。
-ppassword没有空格。
答案 32 :(得分:4)
以下步骤有助于将file.sql
上传到MySQL数据库。
步骤1:将file.sql.zip
上传到任何目录并解压缩
注意:sudo apt-get install unzip
:sudo apt-get unzip file.sql.zip
第2步:现在导航到该目录。示例:cd /var/www/html
第3步:mysql -u username -p database-name < file.sql
输入密码并等到上传完成。
答案 33 :(得分:3)
导入数据库: -
mysql -u username -p database_name&lt; / file path / file_name.sql
从数据库导出: -
mysqldump -u username -p database_name&gt; / file path / file_name.sql
在这些命令提示后会询问你的mysql密码
答案 34 :(得分:2)
如果将数据导入docker容器,请使用以下命令。调整用户(-u),数据库(-D),端口(-P)和主机(-h)以适合您的配置。
mysql -u root -D database_name -P 4406 -h localhost --protocol=tcp -p < sample_dump.sql
答案 35 :(得分:2)
使用 MySQL 安全外壳:
mysqlsh -u <username> -p -h <host> -D <database name> -f dump.sql
答案 36 :(得分:1)
在Windows中,您可以使用以下命令从sql dump中导入数据
C:\ Program Files \ MySQL \ MySQL Server 5.7 \ bin> mysql -u <> -p <> DBName 其中-u后跟用户名,-p后跟Mysql password。可以在提示符下输入密码,因此可以在命令中跳过密码。
答案 37 :(得分:1)
您可以使用:
mysql -u<user> -p<pass> <db> < db.sql
示例:
mysql -uroot -proot db < db.sql
再见!
答案 38 :(得分:1)
如果您的文件夹中有多个SQL文件,并且您已安装Git Bash,则可以使用此命令导入多个文件:
cd /my-project/data
cat *.sql | /c/xampp/mysql/bin/mysql -u root -p 1234 myProjectDbName
答案 39 :(得分:1)
要通过终端导入数据库
导航到sql文件所在的文件夹
以下运行命令
mysql -u database_user_name -p database_name < sql_file_name.sql
它将要求输入密码。输入数据库密码。导入数据库中的数据将需要几秒钟。
答案 40 :(得分:1)
在Ubuntu中
next.config.js
在Windows中
下载SQL文件并将其保存在 mysql -u root -p
CREATE database dbname;
use dbname;
source /home/computername/Downloads/merchantapp.sql
exit;
中。
然后,用C:\xampp\mysql\bin
打开命令提示符:
C:\xampp\mysql\bin
答案 41 :(得分:1)
例如
我在C:\xampp\mysql\bin
上安装了该软件
我的文件位于地址C:\Users\file.sql
只需设置username
和database_name
注意:
首先,您需要手动创建数据库(database_name
)
运行此命令:
cd C:\xampp\mysql\bin && mysql -u username -p database_name < C:\Users\file.sql
然后输入密码
答案 42 :(得分:1)
导出特定数据库:
djimi:> mysqldump --user=root --host=localhost --port=3306 --password=test -B CCR KIT > ccr_kit_local.sql
这将导出CCR和KIT数据库......
将所有导出的数据库导入特定的MySQL实例(您必须在转储文件所在的位置):
djimi:> mysql --user=root --host=localhost --port=3306 --password=test < ccr_kit_local.sql
答案 43 :(得分:1)
此行将转储文件导入linux下的本地数据库中。
mysql -u dbuser -p'password including spaces' dbname < path/to/dump_file.sql
此行将转储文件导入linux下的远程数据库中。注意:-P
用于端口,如果mysql端口与默认端口不同,则为必填项。
mysql -h dbhost -u dbuser -p'password including spaces' -P 3306 dbname < path/to/dump_file.sql
注意:密码包含空格,这是单引号的原因。只需更改在Windows(C:\windows\path\dump_file.sql
)下使用命令的路径样式
答案 44 :(得分:1)
如果您在Mac OS X上使用MAMP,这可能会有所帮助:
/applications/MAMP/library/bin/mysql -u MYSQL_USER -p DATABASE_NAME < path/to/database_sql/FILE.sql
MYSQL_USER默认为root。
答案 45 :(得分:0)
您可以轻松地使用这些步骤。
mysql -u <user> -p<password> <dbname> < file.sql
"file.sql" 是您要插入到目标数据库中的 SQL 文件。 例子: 如果您的“密码”是“1234”&“用户”是“root”&“dbname”是“test”
mysql -u root -p1234 test < file.sql
如果您的“密码”为空且“用户”为“root”且“dbname”为“test”
mysql -u root test < file.sql
此方法可用于在CMD中使用SQL文件上传大尺寸数据。 确保在第 4 步中,如果您使用该密码,请将“-p”作为单个单词插入,不要有任何空格。
答案 46 :(得分:0)
试试这个代码。
mysql -u username -p database_name < file.sql
更多信息:https://slaford.com/mysql/how-to-import-an-sql-file-using-the-command-line-in-mysql/
答案 47 :(得分:0)
要导入数据库,请使用以下命令。
PASS src/stackoverflow/65145829/reducer.test.js (9.086s)
65145829
background reducer
✓ should change background type (4ms)
✓ should add gradient start (1ms)
✓ should add gradient end (1ms)
url reducer
✓ should add url
------------|----------|----------|----------|----------|-------------------|
File | % Stmts | % Branch | % Funcs | % Lines | Uncovered Line #s |
------------|----------|----------|----------|----------|-------------------|
All files | 100 | 100 | 100 | 100 | |
actions.js | 100 | 100 | 100 | 100 | |
reducer.js | 100 | 100 | 100 | 100 | |
------------|----------|----------|----------|----------|-------------------|
Test Suites: 1 passed, 1 total
Tests: 4 passed, 4 total
Snapshots: 0 total
Time: 10.527s
答案 48 :(得分:0)
简单,只需在cmd中使用此命令
use databasename
\. C:/test/data.mysql
答案 49 :(得分:0)
->在MySQL中创建数据库。
->然后转到计算机目录C:\ xampp> mysql> bin。并在地址栏上输入cmd,然后按Enter。
->解压缩sql文件
->然后输入:-mysql -u root -p dbname
,然后按Enter。
->写:-源sql.file。像Source C:\xampp\htdocs\amarbazarltd\st1159.sql
完成
答案 50 :(得分:0)
如果您使用的是xampp,请转到xampp> mysql> bin,然后在此处打开cmd并将其粘贴。
mysql -u root -p dbname
答案 51 :(得分:0)
尝试一下:-
C:\xampp\mysql\bin>mysql -u root -p database_name --force < C:\file.sql
答案 52 :(得分:0)
如果要导入本地数据库服务器,则可以执行以下操作:
git rebase -i -x CodeFormatter.exe --root
对于远程数据库服务器,请执行以下操作:
mysql -u database_user -p < database_file.sql
答案 53 :(得分:-2)
1)转到您的wamp或xampp目录 例子
cd d:/wamp/bin/mysql/mysql5.7.24/bin
2)mysql -u root -p DATABASENAME