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

吾爱主题 阅读:223 2024-04-05 15:10:52 评论:0

在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”概念很简单,意味着文档是“就在这里”,不在外部文件中。

语法如下:

  1. <<MARKER 
  2. ... 
  3. MARKER 

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

看下面的示例:

  1. #!/bin/sh 
  2. mysql -uroot -D yang_db <<QUERY 
  3. SELECT * FROM t_post 
  4. WHERE is_del=0 
  5. AND update_time<="2077-07-07"
  6. QUERY 

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

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

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

原文地址:https://mp.weixin.qq.com/s/YwVei14O2rU1QOSgVTWpcg

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容