如何从Linux命令行直接执行MySQL/MariaDB查询
如果您负责管理数据库服务器,则可能需要不时运行查询并仔细检查它。 虽然您可以从MySQL/MariaDB Shell执行此操作,但此技巧将使您可以直接使用Linux命令行执行MySQL/MariaDB查询,并将输出保存到文件中以供以后检查(这在查询返回时特别有用。 很多记录)。
让我们来看一些直接从命令行运行查询的简单示例,然后再转向更高级的查询。
要查看服务器上的所有数据库,可以发出以下命令:
[linuxidc@localhost ~/www.linuxidc.com]$mysql -u root -p -e "show databases;"
+--------------------+| Database |+--------------------+| idc_db || information_schema || linuxidc_db || mysql || performance_schema || xxx_db |+--------------------+
接
接下来,要在数据库linuxidc_db 中创建一个名为linuxceshi的数据库表,请运行以下命令:
[linuxidc@localhost ~/www.linuxidc.com]$mysql -u root -p -e "USE linuxidc_db ; CREATE TABLE linuxceshi(idc_id INT NOT NULL AUTO_INCREMENT, idc_title VARCHAR(100) NOT NULL, idc_author VARCHAR(40) NOT NULL, submissoin_date DATE, PRIMARY KEY (idc_id));"
查询下表建好没有
[linuxidc@localhost ~/www.linuxidc.com]$mysql -u root -p -e "use linuxidc_db; desc linuxceshi;"
+-----------------+--------------+------+-----+---------+----------------+| Field | Type | Null | Key | Default | Extra |+-----------------+--------------+------+-----+---------+----------------+| idc_id | int(11) | NO | PRI | NULL | auto_increment || idc_title | varchar(100) | NO | | NULL | || idc_author | varchar(40) | NO | | NULL | || submissoin_date | date | YES | | NULL | |+-----------------+--------------+------+-----+---------+----------------+
我们将使用以下命令,并将输出通过管道传递到tee命令,后跟要在其中存储输出的文件名。
为了进行说明,我们将使用一个名为linuxidc数据库的linuxceshi表。请注意,系统将提示您输入数据库用户的密码:
[linuxidc@localhost ~/www.linuxidc.com]$mysql -u root -p -e "use linuxidc_db; desc linuxceshi;" | tee linuxidc_chaxun.txt
借助cat命令查看查询结果。
[linuxidc@localhost ~/www.linuxidc.com]$mysql -u root -p -e "use linuxidc_db; desc linuxceshi;" | tee linuxidc_chaxun.txtEnter password: Field Type Null Key Default Extraidc_id int(11) NO PRI NULL auto_incrementidc_title varchar(100) NO NULL idc_author varchar(40) NO NULL submissoin_date date YES NULL [linuxidc@localhost ~/www.linuxidc.com]$cat linuxidc_chaxun.txtField Type Null Key Default Extraidc_id int(11) NO PRI NULL auto_incrementidc_title varchar(100) NO NULL idc_author varchar(40) NO NULL submissoin_date date YES NULL
使用纯文本文件的查询结果,您可以使用其他命令行实用工具更轻松地处理记录。
小结
本文已经分享了一点Linux技巧,作为系统管理员,您可以在自动执行日常Linux任务或更轻松地执行它们方面发现有用的信息。
留言评论