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

介绍在bash脚本或Linux命令行界面中运行MySQL查询的四种方法。

微信搜索关注《Java学研大本营》

图片

在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

推荐书单

《Linux私教课:技术内核与企业运维篇》

本书围绕Rocky Linux系统,详细地讲解了使用Rocky Linux系统的各项技术要点和企业实战案例。全书共13章,首先对Rocky Linux系统进行介绍。接下来讲解了目录管理与文件管理、用户管理、权限管理、磁盘管理、进程管理、系统管理、网络管理;然后拓展了知识面,讲解了容器管理的内容。最后讲解了Linux系统内核优化、中小型企业上云解决方案、Prometheus监控系统、Podman企业实战。本书充分考虑到零基础读者的阅读需求,精心提供了笔记、示例代码、学习视频、思维导图等资源。

本书适合Linux系统的零基础读者、在校大学生、在职工作人员以及基础比较薄弱、想要系统学习Rocky Linux/Linux系统的读者学习。

《Linux私教课:技术内核与企业运维篇》icon-default.png?t=N7T8https://item.jd.com/14058912.html

精彩回顾

使用Crontab实现Linux任务自动化

使用Docker将Spring Boot应用容器化

7个进行容器管理的Docker命令

7个杀手级IntelliJ IDEA插件

一次搞清Spring 、Spring Boot、Spring Web MVC、Spring WebFlux

微信搜索关注《Java学研大本营》

访问【IT今日热榜】,发现每日技术热点

  • 26
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值