ThinkChat🤖让你学习和工作更高效,注册即送10W Token,即刻开启你的AI之旅 广告
### 第4章:MySQL程序概述 本章简要概述了MySQL AB提供的命令行程序,并讨论了运行这些程序时如何指定选项。大多数程序具有其操作专用的选项,但指定选项的语法都近似。后面的几章更加详细地描述了各个程序,包括它们识别的选项。 MySQL AB还提供了3个GUI客户程序供MySQL服务器使用: ・         [ MySQL管理器](http://dev.mysql.com/doc/administrator/en/):该工具用于管理MySQL服务器、数据库、表以及用户。 ・         [ MySQL查询浏览器](http://dev.mysql.com/doc/query-browser/en/):该图形工具由MySQL AB提供,用于创建、执行以及优化对MySQL数据库的查询。 ・         [ MySQL移植工具包](http://dev.mysql.com/doc/migration-toolkit/en/):该工具可以帮助你将计划和数据从其它关系数据库管理系统移植到MySQL。 ### 4.1. MySQL程序概述 MySQL AB提供了几种类型的程序: ・         MYSQL服务器和服务器启动脚本: o        **mysqld**是MySQL服务器 o        ** mysqld_safe**、**mysql.server**和**mysqld_multi**是服务器启动脚本 o        ** mysql_install_db**初始化数据目录和初始数据库 在[第5章:](#)[_数据库管理_](# "Chapter 5. Database Administration")中详细讨论了这些程序。 ・         访问服务器的客户程序: o        **mysql**是一个命令行客户程序,用于交互式或以批处理模式执行SQL语句。 o        **mysqladmin**是用于管理功能的客户程序。 o        **mysqlcheck**执行表维护操作。 o        **mysqldump**和**mysqlhotcopy**负责数据库备份。 o        ** mysqlimport**导入数据文件。  o        **mysqlshow**显示信息数据库和表的相关信息。 在[第8章:_客户端和实用工具程序_](# "Chapter 8. Client and Utility Programs")中详细讨论了这些程序。 ・         独立于服务器操作的工具程序: o        **myisamchk**执行表维护操作。 o        **myisampack**产生压缩、只读的表。 o        ** mysqlbinlog**是处理二进制日志文件的实用工具。 o        **perror**显示错误代码的含义。 在[第5章:](#)[_数据库管理_](# "Chapter 5. Database Administration")中详细讨论了**myisamchk**。在[第8章:_客户端和实用工具程序_](# "Chapter 8. Client and Utility Programs")中详细讨论了其它程序。 大多数MySQL分发包括上述的全部程序,只是不包含那些与平台相关的程序。(例如,在Windows中不使用服务器启动脚本)。不同的只是RPM分发更加具体化。可能一个RPM是服务器分发,另一个RPM是客户程序分发等等。如果你丢失了一个或多个程序,要想查阅关于分发类型和它们所包含内容的信息,参见[第2章:安装MySQL](# "Chapter 2. Installing MySQL")。也可能需要安装一些其它内容。 ### 4.2. 调用MySQL程序 要想从命令行调用MySQL程序(即从shell或命令提示),应输入程序名,并随后输入指导操作发的选项或其它参量。下面的命令显示了一些程序调用的例子。“shell>”表示命令解释符提示;并不是输入的部分。你所看见的具体提示取决于命令解释符。典型提示符:**sh**或**bash**为$,**csh**或**tcsh**为%,Windows **command.com**或**cmd.exe**为C:\>。 shell> mysql test shell> mysqladmin extended-status variables shell> mysqlshow --help shell> mysqldump --user=root personnel 以破折号开始的参数为选项参量。它们通常指定程序与服务器的连接类型或影响其操作模式。关于选项语法的描述参见[4.3节,“指定程序选项”](# "4.3. Specifying Program Options")。 非选项参数(不以破折号开始的参量)可以为程序提供更详细的信息。例如,**mysql**程序将第一个非选项参量解释为数据库名,因此命令 mysql test表示你想要使用test数据库。 后面的章节描述了具体的程序,表示程序可以理解的选项,并描述了其它非选项参量的含义。 部分选项对部分程序是通用的。最常用的是指定连接参数的--host、--user和--password选项。它们指示MySQL服务器运行的主机和MySQL账户的用户名和 密码。所有MySQL客户程序可以理解这些选项;它们允许你指定连接哪个服务器,以及在该服务器上使用的 账户。 你也许会发现需要使用MySQL程序安装的bin目录的路径名来调用MySQL程序。如果你试图不在bin目录下运行MySQL程序,可能会遇到“程序未找到”错误。为了更方便地使用MySQL,可以将bin目录的路径名添加到PATH环境变量中。然后运行程序时只需要输入程序名,而不需要输入整个路径名。 关于设置PATH的指令的命令解释符请查阅相关文档。设置环境变量的语法与解释符有关。 ### 4.3. 指定程序选项 [ 4.3.1. 在命令行上使用选项](#)[ 4.3.2. 使用选项文件](#)[ 4.3.3. 用环境变量指定选项](#)[ 4.3.4. 使用选项设置程序变量](#) 可以用几种方式提供MySQL程序的选项: ・         在命令行中在程序名后面提供。这对于具体程序调用时使用的选项很普遍。 ・         在程序启动时读取的选项文件中设置。这对于每次程序运行时使用的选项很普遍。 ・         在环境变量中设置。这对每次程序运行时所使用的选项很有用,尽管实际上最常用选项文件。([5.12.2节,“在Unix中运行多个服务器”](# "5.12.2. Running Multiple Servers on Unix")中讨论了环境变量会很有帮助的一种情况。描述了使用这些变量来指定服务器和客户程序的TCP/IP端口号和Unix套接字文件的各种技术)。 MySQL程序首先检查环境变量,然后检查选项文件,然后检查命令行来确定给出了哪些选项。如果多次指定一个选项,最后出现的选项占先。这说明环境变量具有最低的优先级,命令行选项具有最高优先级。 可以在选项文件中指定程序选项的默认值来让MySQL程序处理各选项。不需要在每次运行程序时输入选项,但可以根据需要通过命令行选项来覆盖默认值。 ### 4.3.1. 在命令行上使用选项 在命令行中指定的程序选项遵从下述规则: ・         在命令名后面紧跟选项。 ・         选项参量以一个和两个破折号开始,取决于它具有短名还是长名。许多选项有两种形式。例如,-?和--help是指导MySQL程序显示帮助消息的选项的短名和长名。 ・         选项名对大小写敏感。-v和-V均有效,但具有不同的含义。(它们是--verbose和--version选项的短名)。 ・         部分选项在选项名后面紧随选项值。例如,-h localhost或--host=localhost表示客户程序的MySQL服务器主机。选项值可以告诉程序MySQL服务器运行的主机名。 ・         对于带选项值的长选项,通过一个‘=’将选项名和值隔离开来。对于带选项值的短选项,选项值可以紧随选项字母后面,或者二者之间可以用一个空格隔开。(-hlocalhost和-h localhost是等效的)。该规则的例外情况是指定MySQL密码的选项。该选项的形式可以为--password=_pass_val_或--password。在后一种情况(未给出 密码值),程序将提示输入密码。也可以给出密码选项,短形式为-p_pass_val_或-p。然而,对于短形式,如果给出了 密码值,必须紧跟在选项后面,_中间不能插入空格_。这样要求的原因是如果选项后面有空格,程序没有办法来告知后面的参量是 密码值还是其它某种参量。因此,下面两个命令的含义完全不同: ・                shell> mysql -ptest ・                shell> mysql -p test 第一个命令让**mysql**使用密码test,但没有指定默认数据库。第二个命令让**mysql**提示输入 密码并使用test作为默认数据库。 部分选项控制可以开关的行为。例如,**mysql**客户端支持--column-names选项,确定是否在查询结果开头显示一行栏目名。默认情况,该选项被启用。但是可能在某些情况下你想要禁用它,例如将**mysql**的输出发送到另一个只希望看到数据而不希望看到开始的标题行的程序中。 要想禁用列名,可以使用下面的形式来指定选项: --disable-column-names --skip-column-names --column-names=0 --disable和--skip前缀与=0后缀的效果相同:它们均关闭选项。 可以用下述方法“启用”选项: --column-names --enable-column-names --column-names=1 如果选项有前缀--loose,如果程序未识别出选项不会提示错误退出,但是会发出一条警告: shell> mysql --loose-no-such-option mysql: WARNING: unknown option '--no-such-option' 当你从安装了多个MySQL的同一台机器上运行程序时,--loose前缀会很有用。当你在一个选项文件中列出选项时,该前缀会特别有用。有可能不能被程序的所有版本识别的选项可以冠以--loose前缀(或在选项文件中用loose)。不能识别选项的程序版本将会发出一条警告并忽视该选项。 对**mysql**偶尔有用的另一个选项是-e或--execute选项,可用来将SQL语句传递给服务器。该语句必须用引号引起来(单引号或双引号)。(然而,如果想要在查询中将值引起来,则对于查询应使用双引号,查询中引用的值应使用单引号)。当使用该选项时,语句被执行,然后**mysql**立即退出命令外壳。 例如,你可以用下面的命令获得用户账户列表: shell> mysql -u root -p -e "SELECT User, Host FROM User" mysql Enter password: ****** +------+-----------+ | User | Host      | +------+-----------+ |      | gigan     | | root | gigan     | |      | localhost | | jon  | localhost | | root | localhost | +------+-----------+ shell> 请注意mysql数据库名作为一个独立的参量传递。然而,相同的查询可能已经使用**mysql -u root -p -e "SELECT User,Host FROM mysql.User"**从外壳中执行。 可以按这种方式传递多个SQL语句,用分号隔开: shell> mysql -u root -p --execute="SELECT Name FROM Country WHERE Name LIKE 'AU%';SELECT COUNT(*) FROM City" world Enter password: ****** +-----------+ | Name      | +-----------+ | Australia | | Austria   | +-----------+ +----------+ | COUNT(*) | +----------+ |     4079 | +----------+ 请注意长形式(--execute)后面必须紧跟一个等号(=)。 -e选项也可以以类似方式用来将命令传递给MySQL簇的**ndb_mgm**管理客户端。相关例子参见[17.3.6节,“安全关闭和重启”](# "17.3.6. Safe Shutdown and Restart")。 ### 4.3.2. 使用选项文件 MySQL程序可以从选项文件(有时也称为配置文件)读取启动选项。选项文件提供了一种很方便的方式来指定常用的选项,因此不需要每次运行程序时从命令行输入。 下面的程序支持选项文件:**myisamchk**、**myisampack**、**mysql**、**mysql.server**、**mysqladmin**、**mysqlbinlog**、**mysqlcc**、**mysqlcheck**、**mysqld_safe**、**mysqldump**、**mysqld**、**mysqlhotcopy**、**mysqlimport**和**mysqlshow**。 **注释:**MySQL簇程序使用的选项文件参见[17.4节,“MySQL簇的配置”](# "17.4. MySQL Cluster Configuration")。 在Windows中,MySQL程序从以下文件读取启动选项: <table border="1" cellpadding="0" id="table1"><tr><td> <p><strong><span> 文件名</span></strong></p></td> <td width="349"> <p><strong><span>目的</span></strong></p></td> </tr><tr><td> <p><span><i> <span>WINDIR</span></i><span>\my.ini</span></span></p></td> <td width="349"> <p>全局选项</p></td> </tr><tr><td> <p> <span>C:\my.cnf</span></p></td> <td width="349"> <p>全局选项</p></td> </tr><tr><td> <p><span><i> <span>INSTALLDIR</span></i><span>\my.ini</span></span></p></td> <td width="349"> <p>全局选项</p></td> </tr><tr><td> <p> <span> defaults-extra-file</span></p></td> <td width="349"> <p>用<span>--defaults-extra-file=<i>path</i></span>指定的文件,如果有</p></td> </tr></table> _WINDIR_表示Windows目录的位置。通常为C:\WINDOWS或C:\WINNT。你可以使用下面的命令通过环境变量WINDIR的值确定其确切位置: C:\> echo %WINDIR% _INSTALLDIR_表示MySQL的安装目录。一般为C:\_PROGRAMDIR_\MySQL\MySQL 5.1 Server,其中_PROGRAMDIR_表示程序目录(通常为Windows英文版的Program Files),MySQL 5.1的安装是根据安装和配置向导完成的。参见[2.3.5.14节,“my.ini文件的位置”](# "2.3.5.14. The Location of the my.ini File")。 在Unix中,MySQL程序从下面的文件读取启动选项: <table border="1" cellpadding="0" id="table2"><tr><td> <p><strong><span> 文件名</span></strong></p></td> <td> <p><strong><span>目的</span></strong></p></td> </tr><tr><td> <p> <span>/etc/my.cnf</span></p></td> <td> <p>全局选项</p></td> </tr><tr><td> <p> <span>$MYSQL_HOME/my.cnf</span></p></td> <td> <p>服务器相关选项</p></td> </tr><tr><td> <p> <span> defaults-extra-file</span></p></td> <td> <p>用<span>--defaults-extra-file=<i>path</i></span>指定的文件,如果有</p></td> </tr><tr><td> <p> <span>~/.my.cnf</span></p></td> <td> <p>用户相关选项</p></td> </tr></table> MYSQL_HOME是一个环境变量,包含服务器相关的my.cnf文件驻留的目录路径。 如果未设置MYSQL_HOME,并且_DATADIR_中有一个my.cnf文件,_BASEDIR_中没有my.cnf文件,mysqld_safe将MYSQL_HOME设置为_DATADIR_。否则,如果未设置MYSQL_HOME并且在_DATADIR_中没有my.cnf,则mysqld_safe将MYSQL_HOME设置为_BASEDIR_。 典型情况二进制安装的目录为/usr/local/mysql/data或源代码安装的目录为/usr/local/var。请注意这是配置时指定的数据目录的位置,而不是 **mysqld**启动时用--datadir指定的。运行时使用--datadir对寻找选项文件的服务器没有效果,因为服务器在处理命令行参量之前寻找这些选项。 MySQL按照上述顺序寻找选项文件,并读存在的选项文件。如果你想要使用的某个选项文件不存在,则用明文文本编辑器创建。如果存在多个选项文件,文件中指定的后读取的选项要优先文件中指定的先读取的选项。 **注释:**在Unix平台上,MySQL忽略人人可写的配置文件。这是故意的,是一个安全措施。 任何可以在运行MySQL程序时在命令行给出的长选项也可以在选项文件中给出。要想列出程序的适用选项,用--help选项运行程序。 在选项文件中指定选项的语法类似于命令行语法,例外的是要忽略掉两个破折号。例如,命令行中的--quick或--host=localhost在选项文件中应指定为quick或host=localhost。要想在选项文件中指定--loose-_opt_name_形式的选项,应写为loose-_opt_name_。 选项文件中的空行被忽略掉。非空行可以采用下面任何形式: ・         #_注释_,;_注释_ 注释行以‘#’或‘;’开头。‘#’注释也可以从行的中部开始。 ・         [_group_] _group_是你想要设置选项的程序名或组名。在组行后面,任何_opt_name_或set-variable行适用于组名,直到选项文件结尾或给出其它组行。 ・         _opt_name_ 等价于命令行中的--_opt_name_。 ・         _opt_name_=_value_ 等价于命令行中的--_opt_name_=_value_。在选项文件中,‘=’字符附近可以有空格,而在命令行中是不允许的。你可以用单引号或双引号来引用值。如果值包含一个‘#’注释字符或空格时很有用。 选项名和值前后的空白将自动删除掉。你可以在选项值中使用转义序列‘\b’、‘\t’、‘\n’、‘\r’、‘\\’以及‘\s’来表示退格、tab、换行符、回车以及空格字符。 在Windows中,如果某个选项值表示一个路径名,应使用‘/’而不是‘\’作为路径名间隔符来指定值。如果使用‘\’,必须用双斜线‘\\’,因为‘\’在MySQL中为转义字符。 如果选项组名与程序名相同,则组内的选项专用于该程序。 所有客户程序(但_不能_被**mysqld**)读取[client]选项组。这样允许你指定适用于所有客户端的选项。例如,[client]是用于指定连接服务器的 密码的理想的组。(但应确保该选项文件只能由你自己读写,以便其他人不能发现你的密码)。一定不要随意在[client]组内放置选项,除非它可以被你使用的所有客户程序识别。如果你试图运行程序,如果程序不理解选项则会显示一条错误消息后退出。 从5.0系列的MySQL 5.0.4开始,可以在选项文件中使用!include指令来包括具体文件和!includedir来搜索选项文件的具体目录。例如,要包括文件/home/mydir/myopt.cnf,可以使用: !include /home/me/myopt.cnf 要搜索所有以.cnf结尾的文件的目录/home/mydir并作为选项文件读取,应使用: !includedir /home/mydir 请注意这些选项与节有关。例如,假定你想要使用my.cnf中的某些内容,如下所示: [mysqld] !include /home/mydir/myopt.cnf 在这种情况下,只为该服务器处理文件myopt.cnf,并且!include指令将被客户应用程序忽略。然而,如果你使用下面的部分: [mysqldump] !includedir /home/mydir/my-dump-option 则只有**mysqldump**为以.cnf结尾的文件检查目录/home/mydir/my-dump-option,服务器或其它客户应用程序均不检查。 **注释:**目前,在Unix操作系统中,所发现的使用!includedir指令包括的文件的文件名_必须_以.cnf为扩展名。在Windows中,该指令也为有.ini扩展名(包括.cnf)的文件做检查。 如果你想要创建只由一个具体**mysqld**服务器发布系列读取的选项组,选项组可以用[mysqld-5.0]、[mysqld-5.1]等名称。下面的组表示--new选项只能用于5.1.x 版本的MySQL服务器: [mysqld-5.1] new 下面是一个典型的全局选项文件: [client] port=3306 socket=/tmp/mysql.sock   [mysqld] port=3306 socket=/tmp/mysql.sock key_buffer_size=16M max_allowed_packet=8M   [mysqldump] quick 在上述的选项文件中,设置key_buffer_size和max_allowed_packet变量的行使用了_var_name_=_value_语法。 下面是一个典型的用户选项文件: [client] # The following password will be sent to all standard MySQL clients password="my_password"   [mysql] no-auto-rehash connect_timeout=2   [mysqlhotcopy] interactive-timeout   如果你有一个源代码分发,可以从support-file目录中找到名为my-_xxxx_.cnf的示例选项文件。如果你有一个二进制分发,在MySQL安装目录的support-file目录中查找。在Windows中,示例选项文件也可以位于MySQL的安装目录(如果你不知道在哪里,查阅本节前面或[第2章:安装MySQL](# "Chapter 2. Installing MySQL"))。目前有小、中等、大以及非常大的系统的示例选项文件。要想练习这些文件,在Windows中复制到C:\my.cnf或在Unix中复制到根目录的.my.cnf。 **注释:**在Windows中,可以不显示.cnf选项文件的扩展名。 所有支持选项文件的MySQL程序可以处理下面的命令行选项: ・         --no-defaults 不读取任何选项文件。 ・         --print-defaults 打印从选项文件中获得的程序名和所有选项。 ・         --defaults-file=_path_name_ 只使用给出的选项文件。_path_name_是文件的全路径名。 ・         --defaults-extra-file=_path_name_ 在全局选项文件后但在用户选项文件前读该选项文件。_path_name_是文件的全路径名。 为了正确工作,每个选项必须紧随命令行中的命令名后,例外情况是--print-defaults可以紧随--defaults-file或--defaults-extra-file。 在shell脚本中,可以使用**my_print_defaults**程序来分析选项文件。下面的例子显示了当要求显示[client]和[mysql]组内发现的选项时**my_print_defaults**产生的输出: shell> my_print_defaults client mysql --port=3306 --socket=/tmp/mysql.sock --no-auto-rehash **开发人员请注意**:在C客户程序库中,只是通过处理命令行参量前面的所有匹配选项(即相应组内的选项)来处理选项文件。对于使用多次指定的最后的选项实例的程序,可以很好地工作。如果你有一个C或C++程序按这种方式处理多次指定的选项,但不读取选项文件,只需要添加两行来实现该功能。检查标准MySQL客户程序的源代码来看看如何做。 其它几个MySQL语言接口基于C客户库,它们中的一部分提供了访问选项文件的一种方式。包括Perl和Python。关于接口的详细信息参见相关文档。 ### 4.3.3. 用环境变量指定选项 要想用环境变量指定选项,使用适用注释处理器的语法来设置变量。例如,在Windows或NetWare中,可以设置USER变量来指定MySQL账户名。要想实现,使用语法: SET USER=your_name 在Unix中的语法取决于你的外壳。假定你想要使用MYSQL_TCP_PORT变量指定TCP/IP端口号。典型的语法为(例如**sh**、bash、**zsh**等等): MYSQL_TCP_PORT=3306 export MYSQL_TCP_PORT 第1个命令设置变量,export命令将变量导出到外壳环境,以便其值可供MySQL和其它进程访问。 **csh**和**tcsh**有类似的问题。运行这些外壳时,使用**setenv**使外壳变量适用环境: setenv MYSQL_TCP_PORT 3306 可以在命令提示符下执行设置环境变量的命令,以便立即生效。这些设定值持续到你注销。要向让这些设定值在你每次登录时生效,将相应命令放入每次启动时命令解释符所读的启动文件中。在Windows中典型启动文件为AUTOEXEC.BAT,**bash**为.bash_profile,或者**tcsh**为.tcshrc。关于命令解释符的具体细节请查阅文档。 [附录](#)[F:_环境变量_](# "Appendix F. Environment Variables")了列出影响MySQL程序操作的所有环境变量。 ### 4.3.4. 使用选项设置程序变量 许多MySQL程序有一些内部变量可以在运行时设置。程序变量的设置与带有值的其它长选项相同。例如,**mysql**有一个max_allowed_packet变量,可以控制其通信缓冲区的最大长度。要想为**mysql**将max_allowed_packet变量的值设置为16MB,使用下面的任何一个命令: shell> mysql --max_allowed_packet=16777216 shell> mysql --max_allowed_packet=16M 第1个命令以字节指定值。第2个命令以兆字节指定值。变量值可以有一个后缀K、M或者G(可以为大写或小写)来表示千字节、兆字节或者十亿字节的单位。 在选项文件中,变量设定值没有引导破折号: [mysql] max_allowed_packet=16777216 或: [mysql] max_allowed_packet=16M 如果你喜欢,变量名的下划线可以为破折号。 **注释:**MySQL 5.1仍然能识别旧的语法--set-variable = _option_=_value_,但现在不赞成使用。 部分服务器变量可以在运行时设置。详情参见[5.3.3.1节,“动态系统变量”](# "5.3.3.1. Dynamic System Variables")。 这是MySQL参考手册的翻译版本,关于MySQL参考手册,请访问[dev.mysql.com.](http://dev.mysql.com/doc/mysql/en)。原始参考手册为英文版,与英文版参考手册相比,本翻译版可能不是最新的。