如何在MySQL中运行SQL脚本?

我想在MySQL中执行一个包含SQL查询的文本文件。

我尝试运行source /Desktop/test.sql,并收到错误:

< p > mysql >。回家\ \ sivakumar桌面\ \测试。sql ERROR:无法打开文件 ' \ \ sivakumar \电脑\测试。Sql ',错误:2

你知道我哪里做错了吗?

1090712 次浏览

你有很多选择:

  • 使用MySQL命令行客户端:mysql -h hostname -u user database < path/to/test.sql
  • 安装MySQL GUI工具并打开SQL文件,然后执行它
  • 如果数据库可以通过web服务器访问,请使用phpmysql

如果你在MySQL命令行mysql>,你必须声明SQL文件为source

mysql> source \home\user\Desktop\test.sql;

你可以使用下面的命令来执行已经写入文本文件的mysql语句:

mysql -u yourusername -p yourpassword yourdatabase < text_file

如果你的数据库还没有创建,首先登录到你的mysql使用:

mysql -u yourusername -p yourpassword

然后:

mysql>CREATE DATABASE a_new_database_name

然后:

mysql -u yourusername -p yourpassword a_new_database_name < text_file

这样就行了!

更多信息在这里:http://dev.mysql.com/doc/refman/5.0/en/mysql-batch-commands.html

很有可能,你只需要改变斜杠/黑斜杠: 从< / p >
 \home\sivakumar\Desktop\test.sql

 /home/sivakumar/Desktop/test.sql

因此,命令将是:

source /home/sivakumar/Desktop/test.sql

使用下面的Mysql命令提示符-

source \\home\\user\\Desktop\\test.sql;

不要使用报价。即使路径包含空格(' ')使用完全没有报价

由于mysql -u yourusername -p yourpassword yourdatabase < text_file不能在远程服务器上工作(亚马逊的EC2)…

确保首先创建了数据库。

然后:

mysql --host=localhost --user=your_username --password=your_password your_database_name < pathTofilename.sql

我最喜欢的做法是:

 mysql --user="username" --database="databasename" --password="yourpassword" < "filepath"

我这样使用它是因为当你用""来串的时候,你可以避免错误的路径和空格的错误,而且可能还有更多我没有遇到过的字符问题。


对于@elcuco注释,我建议在使用此命令之前使用[空格],这样它就会告诉bash忽略在历史中保存它,这将在大多数bash中开箱工作。

如果您的命令仍然保存在历史记录中,请查看以下解决方案:

执行不保存在历史记录中的命令 .


额外的安全编辑

如果你想要更加安全,你可以使用以下命令并在命令行输入输入密码:

mysql --user="username" --database="databasename" -p < "filepath"
mysql> source C:\Users\admin\Desktop\fn_Split.sql

不要指定单引号。

如果上述命令无效,请将文件复制到c: drive后重试。 如下所示,

.
mysql> source C:\fn_Split.sql

所有排在前面的答案都是好的。但如果有人想从远程服务器上的文本文件运行查询保存结果到一个文件(而不是显示在控制台),你可以这样做:

mysql -u yourusername -p yourpassword yourdatabase < query_file > results_file

希望这能帮助到一些人。

作为将来的参考,我发现这与前面提到的方法相比,在Windows下的msql控制台:

mysql > > # EYZ0

如果您的根驱动器不叫“c”,那么只需与您的驱动器交换。先试试反斜杠,如果不行,再试试正斜杠。如果它们也不起作用,请确保您有完整的文件路径,文件名上的.sql扩展名,如果您的版本坚持使用分号,请确保它存在并重试。

我犯了这个错误,我尝试了所有我能得到的建议,但都无济于事。

最后,问题是我的文件夹在文件夹名称中有一个空格,在文件夹路径中出现正斜杠,一旦我找到并删除它,它就工作得很好。

我来这里也是为了寻找这个答案,下面是我发现最适合我的答案:注意,我使用的是Ubuntu 16.x.x

  1. 访问mysql使用:

# EYZ0

  1. 在mysql提示符下,输入:

# EYZ0

希望这能有所帮助。

给出.sql文件的路径:

source c:/dump/SQL/file_name.sql;

See In The Image: .

直接从命令行传递password参数绝不是一个好做法,它保存在~/.bash_history文件中,可以从其他应用程序访问。

用这个代替:

mysql -u user --host host --port 9999 database_name < /scripts/script.sql -p
Enter password:
mysql -uusername -ppassword database-name < file.sql

而不是重定向,我会做以下事情

mysql -h <hostname> -u <username> --password=<password> -D <database> -e 'source <path-to-sql-file>'

这将执行文件path-to-sql-file

有很多种方法。

From Workbench: File > Run SQL Script -- then follow prompts


From Windows Command Line:
Option 1: mysql -u usr -p
mysql> source file_path.sql
Option 2: mysql -u usr -p '-e source file_path.sql'
Option 3: mysql -u usr -p < file_path.sql
Option 4: put multiple 'source' statements inside of file_path.sql (I do this to drop and recreate schemas/databases which requires multiple files to be run)
mysql -u usr -p < file_path.sql

如果从命令行得到错误,请确保之前运行过

cd {!!>>mysqld.exe home directory here<<!!}
mysqld.exe --initialize

这必须在mysqld.exe目录中运行,也就是CD。

希望这是有用的,而不是多余的。

从linux 14.04到MySql 5.7,使用cat命令连接MySql登录:

cat /Desktop/test.sql | sudo mysql -uroot -p

您可以使用此方法直接从Shell执行许多MySQL命令。例如:

echo "USE my_db; SHOW tables;" | sudo mysql -uroot -p

请确保使用分号(';')分隔命令。

我在上面的答案中没有看到这种方法,我认为这是一个很好的贡献。

我使用Bash的Here字符串进行即时SQL执行:

mysql -uroot -p <<<"select date(now())"

https://www.gnu.org/software/bash/manual/html_node/Redirections.html#Here-Strings

如果你在这里找一个DRUPAL环境

您可以在项目目录上使用drush命令运行

drush sqlc

如果你正在尝试这个命令:

mysql -u root -proot -D database < /path/to/script.sql

你可能会得到这样的错误:如果你有特殊字符,主要是' "

ERROR 1064 (42000) at line 1: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '/path/to/script.sql' at line 1

所以我建议使用这样的命令:

echo "source /path/to/script.sql" | mysql -u root -proot -D database

一旦连接到执行脚本的服务器,该命令将执行source /path/to/script.sql