首页 文章

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

提问于
浏览
1437

我有 .sql 文件,从 phpMyAdmin 导出 . 我想使用命令行将其导入到不同的服务器中 .

我安装了Windows Server 2008 R2 . 我把 .sql 文件放在 C drive 上,我尝试了这个命令

database_name < file.sql

它不起作用我得到语法错误 .

  • 如何导入此文件没有问题?

  • 我是否需要先创建数据库?

30 回答

  • 5
    mysql --user=[user] --password=[password] [database] < news_ml_all.sql
    
  • 5

    如果.sql文件包含 CREATE DATABASE IF NOT EXISTS db_nameUSE db_name 语句,则无需在命令行上指定数据库的名称 .

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

  • 18

    转到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客户端来执行此操作 .

  • 4

    我正在使用带有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]
    

    它完美无缺,希望它有所帮助 .

    感谢@ Francesco Casulaanswer顺便说一下 .

  • 5

    要一次导入多个SQL文件,请使用以下命令:

    # Unix-based solution
    for i in *.sql;do mysql -u root -pPassword DataBase < $i;done
    

    对于简单导入:

    # Unix-based solution
    mysql -u root -pPassword DataBase < data.sql
    

    对于WAMP

    #mysqlVersion replace with your own version
    C:\wamp\bin\mysql\mysqlVersion\bin\mysql.exe -u root -pPassword DataBase < data.sql
    

    对于XAMPP:

    C:\xampp\mysql\bin\mysql -u root -pPassword DataBase < data.sql
    
  • 4
    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
    
  • 23

    有时,定义的端口以及该数据库的服务器IP address也很重要......

    mysql -u user -p user -h <Server IP> -P<port> (DBNAME) < DB.sql
    
  • 2809

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

    zcat database_file.sql.gz | mysql -u username -p -h localhost database_name
    
  • 14

    我们可以使用此命令从命令行导入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
    
  • 9

    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 command line

    mysql> use db_name;
    mysql> source backup-file.sql;
    
  • 4

    对我有用的解决方案如下:

    Use your_database_name;
    SOURCE path_to_db_sql_file_on_your_local;
    
  • 243

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

    mysqldump -u username -p database_name > database_name.sql
    

    将SQL文件导入数据库(确保您与SQL文件位于同一目录中或提供文件的完整路径)

    mysql -u username -p database_name < database_name.sql
    
  • 86

    尝试:

    mysql -u username -p database_name < file.sql
    

    检查MySQL Options .

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

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

    Note-3 如果它不包含 CREATE DATABASE (使用 --no-create-db-n 选项导出),则可能必须从mysql创建(空)数据库,然后才能导入它 .

  • 4

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

    mysql> use db_name;
     mysql> source file_name.sql;
    
  • 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
    
  • 577

    最简单的导入到您的架构的方法:

    登录mysql并发出以下提示命令 .

    mysql> use your_db_name;
    
    mysql> source /opt/file.sql;
    
  • 57
    • 打开MySQL命令行

    • 键入mysql bin目录的路径,然后按Enter键

    • 将SQL文件粘贴到mysql服务器的 bin 文件夹中 .

    • 在MySQL中创建数据库 .

    • 使用要导入SQL文件的特定数据库 .

    • 键入 source databasefilename.sql 并输入

    • 您的SQL文件上传成功 .

  • 51

    我认为这对使用Mac OS X的人有用:

    /Applications/xampp/xamppfiles/bin/mysql -u root -p database < database.sql
    

    xampp 替换为 mamp 或其他Web服务器 .

  • 39

    导入数据库

    • 去开车:
    command: d:
    
    • MySQL登录
    command: c:\xampp\mysql\bin\mysql -u root -p
    
    • 它会要求pwd . 输入它:
    pwd
    
    • 选择数据库
    use DbName;
    
    • 提供文件名
    \.DbName.sql
    
  • 31

    添加--force option

    mysql -u username -p database_name --force < file.sql
    
  • 12

    以下步骤有助于将 file.sql 上载到MySQL数据库 .

    步骤1:将 file.sql.zip 上传到任何目录并在那里解压缩
    Notesudo apt-get install unzipsudo apt-get unzip file.sql.zip
    第2步:现在导航到该目录 . 示例: cd /var/www/html

    第3步: mysql -u username -p database-name < file.sql
    输入密码并等待上传完成 .

  • 11

    转到您具有MySQL可执行文件的目录 . -u 用于用户名, -p 用于提示输入密码:

    C:\xampp\mysql\bin>mysql -u username -ppassword databasename < C:\file.sql
    
  • 10

    有关信息,我只有默认的root withoutpassword,它不适用于以上所有答案 .

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

    • -ppassword没有空格 .

  • 8

    虽然这里的大多数答案都提到了简单的命令

    mysql -u database_user -p [db_name] <database_file.sql

    今天,数据库和表格的utf8-collation很常见,而这个命令还不够 . 在导出的表中使用utf8-collation,需要使用此命令:

    mysql -u database_user -p --default-character-set = utf8 [db_name] <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版 .

  • 7

    如果您已有数据库,请使用以下命令导入 dumpsql 文件

    mysql -u username -p database_name < file.sql
    

    如果你不需要在MySQL中创建相关数据库(空),首先登录到 MySQL 控制台,方法是在终端或cmd中运行以下命令

    mysql -u userName -p;
    

    并在提示时提供密码 .

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

    mysql>create database yourDatabaseName;
    mysql>use yourDatabaseName;
    

    然后将 sqldump 文件导入到数据库中

    mysql> source pathToYourSQLFile;
    

    注意:如果您的终端不在 dumpsql 文件所在的位置,请使用上面的相对路径 .

  • 7

    要导入单个数据库,请使用以下命令 .

    mysql -u username -p password dbname < dump.sql
    

    要导入多个数据库转储,请使用以下命令 .

    mysql -u username -p password < dump.sql
    
  • 7

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

    你只需要做以下事情:

    mysql> use db_name;
    
    mysql> SET autocommit=0 ; source the_sql_file.sql ; COMMIT ;
    
  • 4

    https://stackoverflow.com/a/17666285/1888983相似
    我的主要区别:

    • 数据库必须首先存在

    • -p 与密码之间没有空格


    shell> mysql -u root -ppassword #note: no space between -p and password
    mysql> CREATE DATABASE databasename;
    mysql> using databasename;
    mysql> source /path/to/backup.sql
    

    使用MariaDB运行fedora 26 .

  • 40

    以下命令适用于Windows 98上WAMP上的命令行(cmd) .

    d:/wamp/bin/mysql/mysql5.6.17/bin/mysql.exe -u root -p db_name < database.sql
    
  • 19

    我一直在遇到没有创建数据库的问题 .

    我这样修好了

    mysql -u root -e "CREATE DATABASE db_name"
    mysql db_name --force < import_script.sql
    

相关问题