四种使用Linux命令查询MySQL的高效方法

系统 Linux
本文总结在bash脚本或Linux命令行界面中运行MySQL查询的四种方法,以便开发人员能够更好地处理MySQL数据库。同时希望能够对所有开发人员提供一个好参考。

在Linux中执行MySQL查询是后端或DevOps开发人员的必备技能。

本文总结在bash脚本或Linux命令行界面中运行MySQL查询的四种方法,以便开发人员能够更好地处理MySQL数据库。同时希望能够对所有开发人员提供一个好参考。

注意:本文中的所有命令都不包括-p选项以输入,因为MySQL已保存在my.cnf文件中

1 使用“-e”选项运行查询

如果只想运行一个简单且短小的SQL查询,可以在查询后面使用-e选项。

mysql -uroot -D yang_db -e "SELECT * FROM t_post"

如上所示,-D选项用于指定要使用的数据库,而-e选项用于执行查询。

2 导入外部SQL文件

有时,数据库管理员可能已经准备了一个包含复杂SQL操作的SQL文件。在这些情况下,仍然可以使用如下的-e选项:

mysql -uroot -D yang_db -e "source ./getPosts.sql"

Linux中的source命令用于读取和执行文件的内容。

3 使用输入重定向导入SQL文件

如果熟悉Linux中的I/O重定向技巧,还有一种方式来导入外部的.sql文件:

mysql -uroot -D yang_db <"./getPosts.sql"

通过这种方式,不需要使用-e选项。使用<操作符就足够了。

4 使用“here-document”处理多行查询

Linux中的“here-document”概念很简单,意味着文档是“就在这里”,不在外部文件中。

语法如下:

<<MARKER
...
MARKER

整个文档都在“MARKER”之内,可以使用任何字符串作为“MARKER”。

看下面的示例:

#!/bin/sh
mysql -uroot -D yang_db <<QUERY
SELECT * FROM t_post
WHERE is_del=0
AND update_time<="2077-07-07";
QUERY

如上所示,使用QUERY作为“MARKER”。内容是要执行的SQL查询。如果把相同的查询写入外部文件并通过之前的方法导入,结果将与“here-document”方法完全相同。

默认情况下,查询的结果将输出到Linux终端。但是,如果结果很大,并且希望将其保存到单独的文件中,可以再次利用I/O重定向技巧:

#!/bin/sh
mysql -uroot -D yang_db >output.txt <<QUERY
SELECT * FROM t_post
WHERE is_del=0
AND update_time<="2077-07-07";
QUERY


责任编辑:武晓燕 来源: Java学研大本营
相关推荐

2014-03-17 09:22:43

Linux命令

2014-02-28 10:50:24

Linux命令

2012-02-29 09:44:54

MySQL

2009-12-09 11:03:45

安装Linux

2021-11-08 12:17:09

LinuxLinux命令编辑照片

2022-12-19 15:25:22

Linux命令

2022-09-20 19:37:08

MySQL

2023-02-10 11:13:42

网络功耗无线网络设备

2010-10-19 17:40:30

SqlServer主键

2010-03-18 17:57:37

Java XMLSoc

2023-08-30 23:41:16

AI框架项目

2009-12-10 14:16:24

2021-12-27 14:20:45

Linux Linux命令

2024-01-17 13:56:00

Redis节点映射关系

2019-08-13 09:00:24

REST API身份认证密钥

2022-07-15 14:43:21

数据安全Linux

2011-05-19 10:44:01

2022-09-02 14:29:01

JavaScrip数组属性

2011-12-30 13:15:53

Java

2009-11-23 15:57:51

PHP伪静态
点赞
收藏

51CTO技术栈公众号