MySQL的交互技巧
发布日期:2016-4-22 12:4:41
MySQL的交互技巧
本文介绍一些与客户端程序mysql进行交互的技巧,这些技巧能帮助我们更有效率地使用它,减少文字输入,希望能帮助大家。此外,本文还会描述“怎样更加方便地连接到服务器”,以及“如何在不经手工输入的情况下输入语句”。 一、简化连接过程 在启动mysql程序时,往往都需要设定某些连接参数,比如:主机名、用户名或者密码。若你在每次启动mysql程序时都输入这么多的内容,那么你就会很快感到厌烦。其实,当我们在连接MySQL服务器时,这里有以下三种办法可以减少打字输入的需要:
1.使用选项文件 MySQL允许把连接参数存储到一个选项文件里。这样,你就不必再在每次启动mysql的时候都输入这些参数了。与在命令行上输入相比,它们的使用效果是一样的。这样做的好处是:其他MySQL客户端程序(如mysqlimport或mysqlshow)也能使用这些参数。也就是说,选项文件不仅能简化mysql的启动过程,也可以让许多其他程序受益。本节对“如何设置客户端程序所用的选项文件”进行了简要介绍。 在Unix系统上,可以创建一个名为~/.my.cnf的文件(即在你的主目录下创建一个名为.my.cnf的文件)来作为选项文件。在Windows系统上,可以在MySQL安装目录下或者在C盘根目录下,创建一个名为my.ini的选项文件(如果在C盘根目录下,就是C:\my.ini)。选项文件是一个纯文本文件,所以可以使用任何一种文本编辑器来创建。选项文件的内容与下面的代码近似: [client] host=server_host user=your_name password=your_pass 说明:[client]行是client选项组的开始标记。MySQL客户端程序会由该行开始读入各行,一直到文件末尾或遇到一个不一样的选项组起始标记为止,从而获得各个选项值。请把其中的server_host、your_name和your_pass分别替换为你在连接MySQL服务器时所用的主机名、用户名与密码。比如,服务器运行在cobra.example.com主机上,MySQL的用户名和密码分别是sampadm与secret,那么请在.my.cnf文件里放入如下所示的几行内容: [client] host=cobra.example.com user=sampadm password=secret 用于定义选项组的起始位置的那个[client]行是必需的,不过,那些用来定义参数值的文本行都是可选的,你可以只列出所需要的那些参数值。比如,你使用的是Unix系统,并且MySQL用户名就是Unix的登录名,那么可以不用包含user那一行。默认的主机是localhost,所如果你要连接的服务器运行在本地主机上,那么host那一行也可以不要。 若是在Unix系统上,那么在创建选项文件之后还需要为它设置访问权限,从而保证其他人不能读取与修改。这里介绍的两条命令都可以实现让选项文件仅限你本人访问,如下所示: % **chmod 600 .my.cnf **% **chmod u=rw,go-rwx .my.cnf** 利用shell的历史命令功能 有些shell程序,如tcsh或bash,能把你在命令行上输入过的命令记录在一个历史清单里,从而可以让你重复其中的命令。如果你使用的是这类shell程序,那么这个历史清单可以帮你避免输入整条的命令。例如,在你刚使用过mysql之后,你可以像下面那样来执行它: % **!my** 感叹号字符(!)的作用是告知shell程序,让它在命令历史清单里,把你最近执行过的以my开头的命令找出来,再执行一次,就好像你在命令行上再次自己输入了它一样。有些shell程序还支持使用键盘上的上下箭头键(或组合键Ctrl+P和Ctrl+N)在命令历史清单里前后移动。这时,在当中选择一条命令之后,按Enter键即可执行它。tcsh和bash具有这样的功能,其他shell可能也有。如果你想了解更多如何使用历史命令列表的信息,可以查阅你所用的shell程序的帮助文档。 2.利用shell别名和脚本 若shell程序支持别名机制,你可以将一个较短的命令名映射到一条较长的命令上。比如,在csh或tcsh里,你就可以像下面这样用alias命令来创建一个名为sampdb的别名,如下所示: alias sampdb 'mysql -h cobra.example.com -p -u sampadm sampdb' 这里bash的语法稍有不同,代码如下所示: alias sampdb='mysql -h cobra.example.com -p -u sampadm sampdb' 利用别名定义之后,就与下面所说的两条命令完全等价,代码如下所示: % **sampdb **% **mysql -h cobra.example.com -p -u sampadm sampdb** 上面所示的代码。我们能很明显地看出第一条命令比第二条简短很多。如若想让这个别名在你每次登录系统时都能生效,那么还需要把alias命令放到shell程序的启动文件里 同样,在Windows系统上也有类似的技巧,那就是可以先创建一个快捷方式指向mysql程序,然后再编辑该快捷方式的属性,让它包含相关的连接参数。 另一种能让你在调用命令时少打字的方法是,创建一个脚本,让它带着恰当的选项执行my``sql。在Unix系统上,一个shell脚本与刚才定义的命令别名sampdb是等价的,代码如下所示: #!/bin/sh exec mysql -h cobra.example.com -p -u sampadm sampdb 若你把这个脚本命名为sampdb,并将其设置为可执行的(使用chmod +x sampdb命令),那么在命令提示符里输入sampdb,即可启动mysql,并连接到sampdb数据库。 在Windows系统上,可以使用批处理文件来完成同样的事情。先创建一个名为sampdb.bat的批处理文件,然后再把下面的内容放入其中,代码如下所示: mysql -h cobra.example.com -p -u sampadm sampdb 执行这个批处理文件的办法有以下所示的两种:
如果需要访问多个数据库或连接多个主机,那么你可以多定义几个别名、快捷方式或者脚本,每一个都以不同的选项参数来调用mysql程序。 二、在调用命令时减少打字输入 mysql从对数据库进行交互式查询的角度来讲是一个极其有用的程序,但是其操作界面却主要适合于输入短小的单行查询命令。由于mysql自身并不关心输入的查询命令是否会延续多少行,但是输入一条长长的查询命令却不是件让人高兴的事。如果因为语法错误而不得不重新输入一遍,那么肯定会让人更郁闷不已。有几种技术可以帮助我们减少不必要的录入工作,如下面的4种方法。
mysql程序支持输入行编辑。你可以编辑当前正在输入的那一行,也可以把以前的输入行调出来,直接再次输入它们,或者在进一步修改之后输入它们。当在输入的命令行中有打字错误的时候,使用这个功能会很方便:在按Enter键之前,可以把光标移到出错位置,对问题进行修正。如果你输入了一个有错误的查询命令,那么可以把它重新调出来,编辑修正问题,然后再次提交。(如果你是在一行里输入了整条查询命令,那么修改起来是最容易的。) 下表列出了一些适用于Unix系统的按键组合,具体内容如表1所示。 表1 在Windows平台上,mysql程序并没有提供行编辑功能。不过,Windows自身支持许多编辑命令,如表1-5所示,因此mysql程序可以直接使用它们。 下表列出了Windows的输入编辑命令,具体内容如表2所示 表2 下面的例子演示了一个输入行编辑功能的简单用法。假设你在mysql程序里输入查询命令,查询命令如下所示: mysql> **SHOW COLUMNS FROM persident****;** 在你按Enter键之前,你突然发现自己把president错拼成了persident,那么可以像下面的这种方法一样修改这条查询命令,方法如下所示:
如果在按Enter键之后才发现打错了字,那么也不要紧。等到mysql显示出错信息之后,按向上键调出刚才输入的那条查询命令,然后像刚才描述的那样将其修改好即可。 利用复制和粘贴来执行语句 如果你使用的是窗口化操作环境,那么可以把你认为有用的那些语句保存到某个文件里,其后通过复制和粘贴操作再次调用它们,方法如下所示:
这一过程看起来比较繁琐,但在掌握之后却相当快捷。它提供了一种无需打字,即可快速输入命令的方式。稍加练习,即可熟练掌握。 你也可以将复制和粘贴的顺序反过来使用(把终端窗口里的语句复制粘贴到你的文件里)。在Unix系统上,当在mysql里输入语句时,这些语句会被保存到位于主目录下的一个名为.mysql_history的文件里。如果你手工输入了一条语句之后,想把它保存起来以供今后使用,那么可以这样做:先退出mysql,再用一个编辑器打开.mysql_history,然后将.mysql_history里的语句复制粘贴到你的那个语句存档文件里。 1.利用mysql执行脚本文件 mysql程序并非只能在交互模式下运行,它也可以在非交互模式(即批处理)下从某个文件里读取输入。如果你有一些需要定期运行的语句,那么此方法会特别有用,因为你不用每次都来重新输入它们。只要在一个文件中保存一次这些语句,就可以根据需要反复地让mysql执行它们。 假设你有一条查询命令,它可以通过member表里的interests列,将那些对某个特定时期的美国历史感兴趣的“美史联盟”成员找出来。比如,想要将那些对Great Depression(美国20世纪30年代的那个大萧条时期)感兴趣的成员找出来,那么可以编写出类似下面这样的查询命令,代码如下所示: SELECT last_name, first_name, email, interests FROM member WHERE interests LIKE '%depression%' ORDER BY last_name, first_name; 把这条查询命令保存在interests.sql文件里,然后像下面这样将它提供给mysql程序执行,代码如下所示: %** mysql sampdb < interests.sql** 默认情况下,当以批处理模式运行时,mysql程序产生的输出内容是以制表符分隔的。如果想得到交互方式运行mysql``时输出的格式效果,可以加上一个-t选项,代码如下所示: % **mysql -t sampdb < interests.sql** 如果想把输出结果保存起来,那么可以将它重定向至一个文件,代码如下所示: % **mysql -t sampdb < interests.sql > ****interests.out** 如果已经运行了mysql,那么可以通过source命令来执行指定文件里的内容,代码如下所示: mysql> **source interests.sql** 如果需要将那些对Thomas Jefferson总统的生平感兴趣的成员查找出来,那么可以先编辑这个文件,把其中的depression改为Jefferson,然后再次运行mysql即可。不过,这个方法只有在你不会频繁地使用这条查询命令时才会显现出优势来。如果要频繁地运行某条查询命令,那么需要另谋出路。在Unix系统上,有一种让查询命令变得更加灵活的方法:先把它保存为一个可以接受脚本命令行参数的shell脚本;然后,用这些命令行参数来更改查询命令的文本内容。这种参数化查询命令的方式,让你可以在运行脚本时指定interests值。通过下面这个shell脚本interests.sh,可以看出其中的工作原理,代码如下所示: #!/bin/sh # interests.sh - find USHL members with particular interests if [ $# -ne 1 ]; then echo 'Please specify one keyword'; exit; fi mysql -t sampdb < SELECT last_name, first_name, email, interests FROM member WHERE interests LIKE '%$1%' ORDER BY last_name, first_name; QUERY_INPUT 在上面的代码中,其中的第3行用于确保命令行参数只有一个;否则,它就会输出一条简短的出错信息,然后退出执行。在<<QUERY_INPUT和最后那个QUERY_INPUT之间的所有内容,都会成为mysql的输入。shell程序会把这段查询命令文本里的脚本变量$1替换为源自命令行的那个参数(在shell程序里,变量$1、$2、``...依次对应于命令行里的各个参数)。这样,在运行这个脚本时,命令行的参数将成为这条查询命令中的检索关键字。 在运行该脚本之前,还必须把它设置为可执行的,代码如下所示: %** chmod +x interests.sh** 现在,你不用在每次运行这个脚本时都去编辑它了。只需通过命令行参数,告诉它你想查找什么东西即可,代码如下所示: % **./interests.sh depression % **./interests.sh Jefferson** 你可以在sampdb发行版的misc目录里找到这个interests.sh脚本。另外,在那里还提供了一个与之等效的Windows批处理文件interests.bat。 {说明} 强烈建议大家不要把这类脚本安装在公共区域里,因为它们在执行时不会对参数进行安全检查,因而很容易遭遇SQL注入攻击。假设有人调用类似下面的脚本发起攻击,代码如下所示: ******% ./interests.sh ****"****Jefferson****'****;DROP DATABASE sampdb;****"*** 此脚本的后果是会有一条DROP DATABASE语句被注入脚本语句中,成为mysql的输入内容。如此一来,这条命令会真的被执行,其后果可想而知。 本文摘自书籍:《MySQL技术内幕》(第5版) 如图1所示: 《MySQL技术内幕》(第5版)是MySQL方面名副其实的经典著作,全面介绍MySQL的基础知识以及MySQL有别于其他数据库系统的独特功能,书中特别关注如何高效地使用和管理MySQL。 全书由4个部分组成:
书中包含大量示例,详尽地演示了MySQL的各项功能特性。此外,本书还为使用C语言、PHP语言和Perl语言开发数据库应用的读者提供了相关内容。 本书不仅适合MySQL初学者阅读,也适合想要深入了解MySQL的数据库管理人员和开发人员参考。 上一条: 京东Presto获开源优秀项目大奖 下一条: mysql主从数据不一致的问题解决过程
|