如何在MySQL中使用命令行导入SQL文件?

如何在MySQL中使用命令行导入SQL文件?,mysql,sql,command-line,import,Mysql,Sql,Command Line,Import,我有一个.sql文件,其中包含从phpMyAdmin导出的内容。我想使用命令行将其导入其他服务器 我安装了R2。我将.sql文件放在C驱动器上,并尝试了这个命令 database_name < file.sql database\u name

我有一个
.sql
文件,其中包含从
phpMyAdmin
导出的内容。我想使用命令行将其导入其他服务器

我安装了R2。我将
.sql
文件放在C驱动器上,并尝试了这个命令

database_name < file.sql
database\u name
它不起作用。我发现语法错误

  • 如何导入此文件而不出现问题
  • 我需要先创建一个数据库吗
试试:

mysql -u username -p database_name < file.sql
mysql-u username-p database\u name
检查

注意-1:最好使用SQL文件
file.SQL的完整路径

注意-2:使用
-R
-triggers
保留原始数据库的例程和触发器。默认情况下不会复制它们

注意-3如果mysql不存在,并且导出的SQL不包含
create database
(使用
--无创建db
-n
选项导出),则可能必须从mysql创建(空)数据库,然后才能导入该数据库。

的常见用法是备份整个数据库:

shell> mysqldump db_name > backup-file.sql
mysqldump -u username -p database_name > file.sql
mysql -u username -p database_name < file.sql
您可以按如下方式将转储文件加载回服务器:

mysql -u root -p password bank < bank.sql
~ ? cd Desktop
~/Desktop ? mysql -u root -p password bank < bank.sql
~/Project ? mysql -u root -p password bank < ~/Desktop/bank.sql
UNIX

shell> mysql db_name < backup-file.sql

转到您拥有MySQL的目录

 c:\mysql\bin\> mysql -u username -p password database_name <
 filename.sql

或者您可以使用一些GUI客户端(如SQLyog)来执行此操作。

我们可以使用此命令从命令行导入SQL:

mysql -u username -p password db_name < file.sql
记住SQL文件的位置。如果您的SQL文件位于
桌面
文件夹/目录中,请转到桌面目录并输入如下命令:

mysql -u root -p password bank < bank.sql
~ ? cd Desktop
~/Desktop ? mysql -u root -p password bank < bank.sql
~/Project ? mysql -u root -p password bank < ~/Desktop/bank.sql

关于导入大文件所需的时间:最重要的是,它需要更多的时间,因为MySQL的默认设置是
autocommit=true
。您必须在导入文件之前将其设置为off,然后检查导入如何像gem一样工作

您只需执行以下操作:

mysql> use db_name;

mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;
mysql--user=[user]--password=[password][database]
导入数据库
  • 前往驾驶室:

     command: d:
    
  • MySQL登录

     command: c:\xampp\mysql\bin\mysql -u root -p
    
  • 它将要求pwd。输入它:

     pwd
    
  • 选择数据库

     use DbName;
    
  • 提供文件名

     \.DbName.sql
    
  • 添加:

    mysql-u用户名-p数据库\u名称--force
    转到MySQL可执行文件所在的目录
    -u
    表示用户名,而
    -p
    表示提示输入密码:

    C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql
    
    C:\xampp\mysql\bin>mysql-u username-ppassword databasename
    我认为它对那些正在使用:

    /Applications/xampp/xamppfiles/bin/mysql-u root-p database
    xampp
    替换为
    mamp
    或其他web服务器

  • 打开MySQL命令行

  • 键入mysql bin目录的路径,然后按Enter键
  • 将SQL文件粘贴到mysql服务器的
    bin
    文件夹中
  • 在MySQL中创建一个数据库
  • 使用要导入SQL文件的特定数据库
  • 键入
    源数据库文件名.sql
    并输入
  • 您的SQL文件上载成功

  • 以下命令在上的命令行(cmd)中对我有效 Windows 7打开

    d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe-u root-p db_name
    要一次导入多个SQL文件,请使用以下命令:

    # Unix-based solution
    for i in *.sql;do mysql -u root -pPassword DataBase < $i;done
    
    基于Unix的解决方案 对于*.sql中的i;做mysql-u root-pPassword数据库<$i;完成
    对于简单导入:

    # Unix-based solution
    mysql -u root -pPassword DataBase < data.sql
    
    基于Unix的解决方案 mysql-u root-pPassword数据库 用于:

    #用您自己的版本替换mysqlVersion
    C:\wamp\bin\mysql\mysqlVersion\bin\mysql.exe-u root-pPassword数据库
    对于XAMPP:

    C:\xampp\mysql\bin\mysql -u root -pPassword DataBase < data.sql
    
    C:\xampp\mysql\bin\mysql-u root-pPassword数据库
    要导入单个数据库,请使用以下命令

    mysql -u username -p password dbname < dump.sql
    
    mysql -u username -p password < dump.sql
    
    mysqldump -u username -p database_name > database_name.sql
    
      mysql> create new_database;
      mysql> use new_database;
      mysql> source (Here you need to import the path of the sql file);
     eg:
      mysql> source E:/test/dump.sql;
    
    mysql-u用户名-p密码dbname
    要导入多个数据库转储,请使用以下命令

    mysql -u username -p password dbname < dump.sql
    
    mysql -u username -p password < dump.sql
    
    mysqldump -u username -p database_name > database_name.sql
    
      mysql> create new_database;
      mysql> use new_database;
      mysql> source (Here you need to import the path of the sql file);
     eg:
      mysql> source E:/test/dump.sql;
    
    mysql-u用户名-p密码
    如果.sql文件包含
    CREATE database if not EXISTS db_name
    USE db_name
    语句,则无需在命令行上指定数据库的名称


    如果.sql文件中提到的数据库不存在,请确保您正在与具有创建数据库权限的用户连接。

    在所有答案中,对于上述问题,这是最好的答案:

     mysql> use db_name;
     mysql> source file_name.sql;
    

    下面是一个适合我的解决方案:

    Use your_database_name;
    SOURCE path_to_db_sql_file_on_your_local;
    

    我认为值得一提的是,您还可以使用
    zcat
    加载gzip(压缩)文件,如下所示:

    zcat database_file.sql.gz | mysql-u username-p-h localhost database_name
    
    关于信息,我只使用了默认的root+而没有密码。以前的答案都不适用

    • 我创建了一个具有所有权限和密码的新用户。成功了

    • -没有空格的单词


    要将数据库转储到SQL文件中,请使用以下命令

    mysql -u username -p password dbname < dump.sql
    
    mysql -u username -p password < dump.sql
    
    mysqldump -u username -p database_name > database_name.sql
    
      mysql> create new_database;
      mysql> use new_database;
      mysql> source (Here you need to import the path of the sql file);
     eg:
      mysql> source E:/test/dump.sql;
    
    要将SQL文件导入数据库(确保与SQL文件位于同一目录或提供文件的完整路径),请执行以下操作:

    mysql-u username-p database\u name
    在命令行上提供凭据不是一个好主意。上面的答案很好,但忽略了提及

    mysql --defaults-extra-file=etc/myhost.cnf database_name < file.sql
    
    类似于

    对我来说,主要区别是:

  • 数据库必须首先存在
  • -p
    和密码之间没有空格


  • 我正在使用MariaDB运行Fedora 26。

    如果您已经拥有数据库,请使用以下命令导入
    转储文件或
    sql
    文件:

    mysql -u username -p database_name < file.sql
    
    并在提示时提供密码

    接下来,创建一个数据库并使用它:

    mysql>create database yourDatabaseName;
    mysql>use yourDatabaseName;
    
    然后导入
    sql
    mysql -u root -p password -D database_name << import.sql
    [~]$ 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.
    
    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
    
    mysqldump -u username –-password=your_password database_name > file.sql
    
    mysql -u username –-password=your_password database_name < file.sql
    
    mysql> use your_db_name;
    
    mysql> source /opt/file.sql;
    
    mysqldump -u username -p database_name > file.sql
    
    mysql -u username -p database_name < file.sql
    
      mysql> create new_database;
      mysql> use new_database;
      mysql> source (Here you need to import the path of the sql file);
     eg:
      mysql> source E:/test/dump.sql;