- 浏览: 109295 次
- 性别:
- 来自: 长沙
最新评论
-
吉米家:
水晶报表的话,登录的确不是很好用,相比之下,帆软报表更加实用一 ...
水晶报表读取Web.config 登陆设置 -
wyqdl:
请问mysql-2.7.3-mswin32.gem这个文件从哪 ...
解决Rails2.33 与Mysql连接问题 -
wohaizai007:
你好,我是ruby初学者,你的资料没有下下来,请问怎么联系你, ...
学习ruby on rails的视频教程和电子书下载 -
allwefantasy:
zhangbo520 写道没想到出现No definition ...
Ruby on Rails 安装札记 -
zhangbo520:
没想到出现No definition for dummy_du ...
Ruby on Rails 安装札记
第8章:客户端和实用工具程序
目录
8.1. 客户端脚本和实用工具概述
8.2. myisampack:生成压缩、只读MyISAM表
8.3. mysql:MySQL命令行工具
8.3.1. 选项
8.3.2. mysql命令
8.3.3. 怎样从文本文件执行SQL语句
8.3.4. mysql技巧
8.4. mysqlaccess:用于检查访问权限的客户端
8.5. mysqladmin:用于管理MySQL服务器的客户端
8.6. mysqlbinlog:用于处理二进制日志文件的实用工具
8.7. mysqlcheck:表维护和维修程序
8.8. mysqldump:数据库备份程序
8.9. mysqlhotcopy:数据库备份程序
8.10. mysqlimport:数据导入程序
8.11. mysqlshow-显示数据库、表和列信息
8.12. myisamlog:显示MyISAM日志文件内容
8.13. perror:解释错误代码
8.14. replace:字符串替换实用工具
8.15. mysql_zap:杀死符合某一模式的进程
有许多不同的MySQL客户端程序可以连接服务器以访问数据库或执行管理任务。也可以使用其它工具。这些程序不与服务器进行通讯但可以执行MySQL相关的操作。
本章简述了这些程序然后详细描述了每个程序。描述了如何调用这些程序和它们理解的选项。调用程序和指定程序选项的总信息参见第4章:MySQL程序概述。
8.1. 客户端脚本和实用工具概述
下面简单列出了MySQL客户端程序和实用工具:
· myisampack
压缩MyISAM表以产生更小的只读表的一个工具。参见8.2节,“myisampack:生成压缩、只读MyISAM表”。
· mysql
交互式输入SQL语句或从文件以批处理模式执行它们的命令行工具。参见8.3节,“mysql:MySQL命令行工具”。
· mysqlaccess
检查访问主机名、用户名和数据库组合的权限的脚本。
· mysqladmin
执行管理操作的客户程序,例如创建或删除数据库,重载授权表,将表刷新到硬盘上,以及重新打开日志文件。mysqladmin还可以用来检索版本、进程,以及服务器的状态信息。参见8.5节,“mysqladmin:用于管理MySQL服务器的客户端”。
· mysqlbinlog
从二进制日志读取语句的工具。在二进制日志文件中包含的执行过的语句的日志可用来帮助从崩溃中恢复。参见8.6节,“mysqlbinlog:用于处理二进制日志文件的实用工具”。
· mysqlcheck
检查、修复、分析以及优化表的表维护客户程序。参见8.7节,“mysqlcheck:表维护和维修程序”。
· mysqldump
将MySQL数据库转储到一个文件(例如SQL语句或tab分隔符文本文件)的客户程序。增强版免费软件首先由Igor Romanenko提供。参见8.8节,“mysqldump:数据库备份程序”。
· mysqlhotcopy
当服务器在运行时,快速备份MyISAM或ISAM表的工具。参见8.9节,“mysqlhotcopy:数据库备份程序”。
· mysql import
使用LOAD DATA INFILE将文本文件导入相关表的客户程序。参见8.10节,“mysqlimport:数据导入程序”。
· mysqlshow
显示数据库、表、列以及索引相关信息的客户程序。参见8.11节,“mysqlshow:显示数据库、表和列信息”。
· perror
显示系统或MySQL错误代码含义的工具。参见8.13节,“perror:解释错误代码”。
· replace
更改文件中或标准输入中的字符串的实用工具。参见8.14节,“replace:字符串替换实用工具”。
MySQL AB还提供了大量GUI工具用于管理和MySQL服务器的其它工作。相关基本信息参见第4章:MySQL程序概述。
每个MySQL程序有许多不同的选项。但每个MySQL程序均提供一个---help选项,可以用来全面描述程序不同的选项。例如,可以试试mysql---help。
使用mysqlclient库同服务器进行通讯的MySQL客户使用下面的环境变量:
MYSQL_UNIX_PORT
默认Unix套接字文件;用于连接localhost
MYSQL_TCP_PORT
默认端口号;用于TCP/IP连接
MYSQL_PWD
默认密码
MYSQL_DEBUG
调试过程中的调试跟踪选项
TMPDIR
创建临时表和文件的目录
使用MYSQL_PWD不安全。参见5.8.6节,“使你的密码安全”。
可以在选项文件中或在命令行中指定选项来替换所有标准程序的默认选项值或指定的环境变量的值。参见4.3节,“指定程序选项”。
8.2. myisampack:生成压缩、只读MyISAM表
myisampack工具可以压缩MyISAM表.MYIsampack分别压缩表中的每一列。通常,myisampack可以将数据文件压缩到40%-70%。
当以后使用表时,解压缩列需要的信息被读入内存。当访问具体的记录时性能会更好,因为你只需要解压缩一个记录。
MySQL使用mmap()对压缩的表进行内存映射。如果mmap()不工作,MySQL返回到普通读/写文件操作。
请注意:
· 如果用--skip-external-locking选项调用mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好注意。
· 表压缩后,它变为只读。这是故意的(例如当访问CD上的压缩的表时)。允许写入到压缩的表位于我们的TODO列表中,但优先级较低。
· myisampack可以压缩BLOB或TEXT列。旧版本ISAM表的pack_isam程序不可以。
调用myisampack的方法:
shell> myisampack [options] filename ...文件名应为索引(.MYI)文件的文件名。如果不在数据库目录,应指定文件的路径名。允许忽略.MYI扩展名。
myisampack支持下面的选项:
· --help,-?
显示帮助消息并退出。
· --backup,-b
使用tbl_name.OLD名备份表数据文件。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。
· --force,-f
产生一个压缩的表,即使它比原始表大,或如果以前调用myisampack的中间文件存在。(myisampack压缩表时在数据库目录中创建一个名为tbl_name.TMD的中间文件。如果杀掉myisampack,.TMD文件会被删除)。通常情况,如果myisampack发现tbl_name.TMD存在则退出并提示错误。用--force,myisampack则一定压缩表。
· -join=big_tbl_name,-j big_tbl_name
将命令行中的所有表联接为一个表big_tbl_name。将要连接的所有表必须有相等的结构(相同的列名和类型,相同的索引等等)。
· --pack length=len,-p len
指定记录长度存储大小,以字节计。值应为1、2或者3。myisampack保存所有长度指针为1、2或者3字节的行。在大多数正常情况下,myisampack在开始压缩文件前可以确定准确的长度值,但在压缩过程中它可以提示它可能已经使用了一个短的长度。在这种情况下,myisampack输出一条提示,下次你压缩同一文件时,你可以使用更短的记录长度。
· --silent,-s
沉默模式。只有发生错误时才写输出。
· --test,-t
没有实际地压缩表,只是测试压缩。
· --tmpdir=path,-T path
使用myisamchk创建临时文件的目录。
· --verbose,-v
冗长模式。写压缩操作过程相关信息和其结果。
· --version,-V
显示版本信息并退出。
· --wait,-w
如果表正使用则等待并重试。如果用--skip-external-locking选项调用了mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好注意。
下面的顺序命令说明了典型的表压缩会话:
shell> ls -l station.*-rw-rw-r-- 1 monty my 994128 Apr 17 19:00 station.MYD-rw-rw-r-- 1 monty my 53248 Apr 17 19:00 station.MYI-rw-rw-r-- 1 monty my 5767 Apr 17 19:00 station.frm shell> myisamchk -dvv station MyISAM file: stationIsam-version: 2Creation time: 1996-03-13 10:08:58Recover time: 1997-02-02 3:06:43Data records: 1192 Deleted blocks: 0Datafile parts: 1192 Deleted data: 0Datafile pointer (bytes): 2 Keyfile pointer (bytes): 2Max datafile length: 54657023 Max keyfile length: 33554431Recordlength: 834Record format: Fixed length table description:Key Start Len Index Type Root Blocksize Rec/key1 2 4 unique unsigned long 1024 1024 12 32 30 multip. text 10240 1024 1 Field Start Length Type1 1 12 2 43 6 44 10 15 11 206 31 17 32 308 62 359 97 3510 132 3511 167 412 171 1613 187 3514 222 415 226 1616 242 2017 262 2018 282 2019 302 3020 332 421 336 422 340 123 341 824 349 825 357 826 365 227 367 228 369 429 373 430 377 131 378 232 380 833 388 434 392 435 396 436 400 437 404 138 405 439 409 440 413 441 417 442 421 443 425 444 429 2045 449 3046 479 147 480 148 481 7949 560 7950 639 7951 718 7952 797 853 805 154 806 155 807 2056 827 457 831 4 shell> myisampack station.MYICompressing station.MYI: (1192 records)- Calculating statistics normal: 20 empty-space: 16 empty-zero: 12 empty-fill: 11pre-space: 0 end-space: 12 table-lookups: 5 zero: 7Original trees: 57 After join: 17- Compressing file87.14%Remember to run myisamchk -rq on compressed tables shell> ls -l station.*-rw-rw-r-- 1 monty my 127874 Apr 17 19:00 station.MYD-rw-rw-r-- 1 monty my 55296 Apr 17 19:04 station.MYI-rw-rw-r-- 1 monty my 5767 Apr 17 19:00 station.frm shell> myisamchk -dvv station MyISAM file: stationIsam-version: 2Creation time: 1996-03-13 10:08:58Recover time: 1997-04-17 19:04:26Data records: 1192 Deleted blocks: 0Datafile parts: 1192 Deleted data: 0Datafile pointer (bytes): 3 Keyfile pointer (bytes): 1Max datafile length: 16777215 Max keyfile length: 131071Recordlength: 834Record format: Compressed table description:Key Start Len Index Type Root Blocksize Rec/key1 2 4 unique unsigned long 10240 1024 12 32 30 multip. text 54272 1024 1 Field Start Length Type Huff tree Bits1 1 1 constant 1 02 2 4 zerofill(1) 2 93 6 4 no zeros, zerofill(1) 2 94 10 1 3 95 11 20 table-lookup 4 06 31 1 3 97 32 30 no endspace, not_always 5 98 62 35 no endspace, not_always, no empty 6 99 97 35 no empty 7 910 132 35 no endspace, not_always, no empty 6 911 167 4 zerofill(1) 2 912 171 16 no endspace, not_always, no empty 5 913 187 35 no endspace, not_always, no empty 6 914 222 4 zerofill(1) 2 915 226 16 no endspace, not_always, no empty 5 916 242 20 no endspace, not_always 8 917 262 20 no endspace, no empty 8 918 282 20 no endspace, no empty 5 919 302 30 no endspace, no empty 6 920 332 4 always zero 2 921 336 4 always zero 2 922 340 1 3 923 341 8 table-lookup 9 024 349 8 table-lookup 10 025 357 8 always zero 2 926 365 2 2 927 367 2 no zeros, zerofill(1) 2 928 369 4 no zeros, zerofill(1) 2 929 373 4 table-lookup 11 030 377 1 3 931 378 2 no zeros, zerofill(1) 2 932 380 8 no zeros 2 933 388 4 always zero 2 934 392 4 table-lookup 12 035 396 4 no zeros, zerofill(1) 13 936 400 4 no zeros, zerofill(1) 2 937 404 1 2 938 405 4 no zeros 2 939 409 4 always zero 2 940 413 4 no zeros 2 941 417 4 always zero 2 942 421 4 no zeros 2 943 425 4 always zero 2 944 429 20 no empty 3 945 449 30 no empty 3 946 479 1 14 447 480 1 14 448 481 79 no endspace, no empty 15 949 560 79 no empty 2 950 639 79 no empty 2 951 718 79 no endspace 16 952 797 8 no empty 2 953 805 1 17 154 806 1 3 955 807 20 no empty 3 956 827 4 no zeros, zerofill(2) 2 957 831 4 no zeros, zerofill(1) 2 9myisampack显示下面的各种信息:
· normal
不需要进行额外压缩的列的数量。
· empty-space
只包含空格的列的数量;占一个比特。
· empty-zero
只包含二进制零的列的数量;占一个比特。
· empty-fill
不占该类全字节范围的整数列的数量;这些列被改为较小的类型。例如,如果所有值的范围为从-128到127,BIGINT列(8个字节)可以保存为TINYINT列(1个字节)。
· pre-space
用引导空格保存的十进制列的数量。在这种情况下,每个值包含一个引导空格的数量计数。
· end-space
有大量结尾空格的列的数量。在这种情况下,每个值包含一个结尾空格的数量计数。
· table-lookup
该列只有少量的不同的值,在进行哈夫曼压缩前被转换为一个ENUM。
· zero
所有值为零的列的数量。
· Original trees
哈夫曼树的最初数量。
· After join
联接树以节省一些头空间之后留下的哈夫曼树的数量。
表被压缩后,myisamchk -dvv为每列输出详细信息:
· Type
列的类型。该值可以包含下面的任何描述符:
o constant
所有行具有相同的值。
o no endspace
不保存结尾空格。
o no endspace,not_always
不保存结尾空格并且对于所有的值不压缩结尾空格。
o no endspace,no empty
不保存结尾空格。不保存空值。
o table-lookup
列被转换为一个ENUM。
o zerofill(n)
值中最有意义的n字节总为0,并且不保存。
o no zeros
不保存零。
o always zeros
用一个位保存零值。
· Huff tree
列相关的哈夫曼树的数量。
· Bits
哈夫曼树使用的位数。
运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作:
shell> myisamchk -rq --sort-index --analyze tbl_name.MYI将压缩的表安装到MySQL数据库目录中后,应执行mysqladmin flush-tables以强制mysqld使用新的表。
要想解压缩一个压缩的表,使用myisamchk或isamchk的--unpack选项。
8.3. mysql:MySQL命令行工具
8.3.1. 选项
8.3.2. mysql命令
8.3.3. 怎样从文本文件执行SQL语句
8.3.4. mysql技巧
mysql是一个简单的SQL外壳(有GNU readline功能)。它支持交互式和非交互式使用。当交互使用时,查询结果采用ASCII表格式。当采用非交互式(例如,用作过滤器)模式时,结果为tab分割符格式。可以使用命令行选项更改输出格式。
如果由于结果较大而内存不足遇到问题,使用--quick选项。这样可以强制mysql从服务器每次一行搜索结果,而不是检索整个结果集并在显示之前不得不将它保存到内存中。使用mysql_use_result()而不是mysql_store_result()来搜索结果集。
使用mysql很简单。从命令解释符提示来调用它:
shell> mysql db_name或:
shell> mysql --user=user_name --password=your_password db_name这样输入一个SQL语句,用‘;’、\g或者\G结尾并按回车键。
你可以这样运行一个脚本:
shell> mysql db_name < script.sql > output.tab8.3.1. 选项
mysql支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --batch,-B
打印结果,使用tab作为列间隔符,每个行占用新的一行。使用该选项,则mysql不使用历史文件。
· --character-sets -dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --compress,-C
压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。
· ---database=db_name,-D db_name
要使用的数据库。主要在选项文件中有用。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。 默认为'd:t:o,/tmp/mysql.trace'。
· ---debug-info,-T
当程序退出时输出部分调试信息。
· --default-character-set=charset
使用charsetas作为默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --execute=statement, -e statement
执行语句并退出。默认输出格式与用--batch产生的相同。4.3.1节,“在命令行上使用选项”中提供了一些例子。
· --force,-f
即使出现一个SQL错误仍继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --html,-H
产生HTML输出。
· --ignore-space,-i
忽视函数名后面的空格。其结果描述参见5.3.2节,“SQL服务器模式”中的IGNORE_SPACE的讨论。
· --local-infile[={0|1}]
为LOAD DATA INFILE启用或禁用LOCAL功能。没有值,该选项启用LOCAL。还可以采用--local-infile=0或--local-infile=1以显式禁用或启用LOCAL。如果服务器不支持,启用LOCAL不会生效。
· --named-commands,-G
命名的命令被启用。允许长格式命令和短格式\*命令。例如,quit和\q均被识别。
· --no-auto-rehash,-A
不自动重新进行哈希运算。该选项使mysql启动得更快,但果你想要完成表和列名,你必须发出rehash命令。
· --no-beep,-b
当发生错误时不要保持。
· --no-named-commands,-g
命名的命令被禁用。只使用\*形式,或者只使用行开头的命名用分号(‘;’)结束的的命令。对于MySQL 3.23.22,默认情况mysql启动时启用该选项。然而,即使使用该选项,长格式命令仍然从第1行工作。
· --no-pager
不使用分页器来显示查询输出。在8.3.2节,“mysql命令”中详细讨论了输出分页。
· --no-tee
不将输出复制到文件中。在8.3.2节,“mysql命令”中详细讨论了Tee文件。
· --one--database,-O
忽视除了为命令行中命名的默认数据库的语句。可以帮助跳过对二进制日志中的其它数据库的更新。
· --pager[=command]
使用给出的命令来分页查询输出。如果该命令被删除,默认分页器为PAGER环境变量的值。合法pagers是less、more、cat [>filename]等等。该选项只在Unix中工作。不能以批处理模式工作。在8.3.2节,“mysql命令”中详细讨论了输出分页。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。在SysV-based UNIX系统中应省略密码,因为密码可以显示在ps的输出中。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --prompt=format_str
将提示设置为指定的格式。默认为mysql>。在8.3.2节,“mysql命令”中描述了提示中可以包含的具体顺序。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --quick,-q
不缓存每个查询的结果,按照接收顺序打印每一行。如果输出被挂起,服务器会慢下来。使用该选项,mysql不使用历史文件。
· --raw,-r
写列的值而不转义转换。通常结合--batch选项使用。
· --reconnect
如果与服务器之间的连接断开,自动尝试重新连接。每次连接断开后则尝试一次重新连接。要想禁止重新连接,使用--skip-reconnect。
· --safe-updates,--i-am-a-dummy,-U
只允许那些使用键值指定行生效的UPDATE和DELETE语句。如果已经在选项文件中设置了该选项,可以用命令行中的--safe-updates覆盖它。关于该选项的详细信息参见8.3.4节,“mysql技巧”。
· --secure-auth
不向旧(pre-4.1.1)格式的服务器发送密码。这样可以防止不使用新密码格式的服务器的连接。
· --show-warnings
如果每个语句后有警告则显示。该选项适用于交互式和批处理模式。
· --sigint-ignore
忽视SIGINT符号(一般为Control-C的结果)。
· --silent,-s
沉默模式。产生少的输出。可以多次使用该选项以产生更少的输出。
· --skip-column-names,-N
在结果中不写列名。
· --skip-line-numbers,-L
在错误信息中不写行号。当你想要比较包括错误消息的结果文件时有用。
· --socket=path,-S path
用于连接的套接字文件。
· --tables,-t
用表格式显示输出。这是交互式应用的默认设置,但可用来以批处理模式产生表输出。
· --tee=file_name
将输出拷贝添加到给定的文件中。该选项在批处理模式不工作。在8.3.2节,“mysql命令”中详细讨论了Tee文件。
· --unbuffered,-n
每次查询后刷新缓存区。
· --user=user_name,-u user_name
当连接服务器时MySQL使用的用户名。
· --verbose,-v
冗长模式。产生更多的输出。可以多次使用该选项以产生更多的输出。(例如,-v -v -v甚至可以在批处理模式产生表输出格式)。
· --version,-V
显示版本信息并退出。
· --vertical,-E
垂直输出查询输出的行。没有该选项,可以用\G结尾来指定单个语句的垂直输出。
· --wait,-w
如果不能建立连接,等待并重试而不是放弃。
· --xml,-X
产生XML输出。
你还可以使用--var_name=value选项设置下面的变量:
· connect_timeout
连接超时前的秒数。(默认值是0)。
· max_allowed_packet
从服务器发送或接收的最大包长度。(默认值是16MB)。
· max_join_size
当使用--safe-updates时联接中的行的自动限制。(默认值是1,000,000)。
· net_buffer_length
TCP/IP和套接字通信缓冲区大小。(默认值是16KB)。
· select_limit
当使用--safe-updates时SELECT语句的自动限制。(默认值是1,000)。
也可以使用--set-variable=var_name=value or -O var_name=value语法来设置变量。不赞成使用该语法。
在Unix中,mysql客户程序向历史文件中写入已执行语句的一条记录。默认情况,历史文件名为.mysql_history并在根目录中重建。要想指定不同的文件,应设置MYSQL_HISTFILE环境变量的值。
如果不想要历史文件,首先删除.mysql_history(如果有),然后使用下面的任何一种方法:
· 将MYSQL_HISTFILE变量设到/dev/null。要想在每次登录时让该设置生效,将该设置放入外壳的一个启动文件中。
· 创建.mysql_history,作为一个符号链接指向/dev/null:
· shell> ln -s /dev/null $HOME/.mysql_history只需要执行一次。
8.3.2. mysql命令
mysql将发出的SQL语句发送到待执行的服务器。还有一系列命令mysql可以自己解释。要查看这些命令,在mysql>提示下输入help或\h:
mysql> help
List of all MySQL commands:
Note that all text commands must be first on line and end with ';'
? (\?) Synonym for `help'.
clear (\c) Clear command.
connect (\r) Reconnect to the server. Optional arguments are db and host.
delimiter (\d) Set statement delimiter. NOTE: Takes the rest of the line as new delimiter.
edit (\e) Edit command with $EDITOR.
ego (\G) Send command to mysql server, display result vertically.
exit (\q) Exit mysql. Same as quit.
go (\g) Send command to mysql server.
help (\h) Display this help.
nopager (\n) Disable pager, print to stdout.
notee (\t) Don't write into outfile.
pager (\P) Set PAGER [to_pager]. Print the query results via PAGER.
print (\p) Print current command.
prompt (\R) Change your mysql prompt.
quit (\q) Quit mysql.
rehash (\#) Rebuild completion hash.
source (\.) Execute a SQL script file. Takes a file name as an argument.
status (\s) Get status information from the server.
system (\!) Execute a system shell command.
tee (\T) Set outfile [to_outfile]. Append everything into given outfile.
use (\u) Use another database. Takes database name as argument.
warnings (\W) Show warnings after every statement.
nowarning (\w) Don't show warnings after every statement.
每个命令有长形式和短形式。长形式对大小写不敏感;短形式敏感。长形式后面可以加一个分号结束符,但短形式不可以。
在delimiter命令中,应避免使用反斜线(‘\’),因为这是MySQL的转义符。
Edit、nopager、pager和system命令只在Unix中工作。
status命令提供连接和使用的服务器相关的部分信息。如果用--safe-updates模式运行,status也打印影响查询的MySQL变量的值。
要想记录查询及其输出,应使用tee命令。屏幕上显示的所有数据被追加到给定的文件后面。这对于调试也很有用。可以用--tee选项在命令行中启用该特性,或者用tee命令交互式启用。可以用notee命令交互式禁用tee文件。再次执行tee可以重新启用日志。前面的文件使用时不带任何参数。请注意执行完每个语句后tee可以将查询结果刷新到一个文件中,并且在mysql打印下一个提示前刷新。
用--pager选项,可以用交互式模式使用Unix程序,例如less、more或者其它类似的程序,来浏览或搜索查询结果。如果未指定该选项的值,mysql检查PAGER环境变量的值并将PAGER设为该值。可以用pager命令交互式启用输出分页,并用nopager禁用。该命令采用可选参量;如果给出,分页程序设置为该值。如果没有给出参量,分页器被设置为在命令行中设置的分页器的值,如果未指定分页器,则设置为stdout。
输出分页只适合Unix,因为它使用popen()函数,该函数在Windows中不存在。在Windows中,可以使用tee选项来保存查询输出,尽管在某些情况下浏览输出时不如pager方便。
关于pager命令的一些技巧:
· 可以使用它写入一个文件,将结果只输出到该文件中:
· mysql> pager cat > /tmp/log.txt也可以为将用作分页器的程序传递选项:
mysql> pager less -n -i -S· 注意前面例子中的-S选项。它可以帮助浏览广范围的查询结果。有时太广的结果很难在屏幕上读出来。less的-S选项可以使结果更易于读,因为可以用左、右箭头水平滚动它。还可以在less中交互式使用-S,以关闭或打开水平浏览模式。详细信息请阅读手册中的less页:
· shell> man less· 可以指定很复杂的pager命令来处理查询输出:
· mysql> PAGER cat | tee /dr1/tmp/res.txt \· | tee /dr2/tmp/res2.txt | less -n -i -S在该例子中,该命令将查询结果发送到位于/dr1和/dr2上安装的两个不同的文件系统中的两个不同目录中的两个文件中,但仍然可以通过less将结果显示在屏幕上。
还可以结合使用tee和pager函数。启用一个tee文件并将pager设置为less,能够使用less 程序浏览结果,并且仍然可以同时将内容添加到一个文件中。结合pager命令使用的Unix tee和 mysql嵌入式tee命令的差别是即使没有可用的Unix tee,嵌入式tee仍然可以工作。嵌入式tee还可以记录在屏幕上输出的内容,而结合pager命令使用的Unix tee不能记录那么多的内容。并且,可以从MySQL中交互式打开或关闭tee文件日志。当你想要将部分查询记录到一个文件中时很有用,但其它不适合。
默认mysql>提示符可以重新配置。定义提示符的字符串可以包含下面的特殊序列:
选项
描述
\v
服务器版本
\d
当前的数据库
\h
服务器主机
\p
当前的TCP/IP端口或套接字文件
\u
你的用户名
\U
你的全user_name@host_name账户名
\\
‘\’反斜线字符
\n
新行字符
\t
Tab字符
\
空格(反斜线后面的空格)
\_
空格
\R
当前的时间,24-小时军用时间(0-23)
\r
当前的时间,标准12-小时(1-12)
\m
当前时间的分钟
\y
当前的年,两位
\Y
当前的年,四位
\D
当前的日期
\s
当前时间的秒
\w
当前周的天,3字符格式(Mon,Tue,...)
\P
am/pm
\o
当前的月,数字格式
\O
当前的月,3字符格式(Jan,Feb,...)
\c
随发出的每个语句递增的计数
\S
分号
\'
单引号
\"
双引号
‘\’后面跟随的其它字母则变为该字母。
如果不用任何参量指定提示命令,mysql将提示重新设置位默认mysql>。
可以用几种方式设置提示:
· 使用环境变量
可以用MYSQL_PS1环境变量来设置提示字符串。例如:
shell> export MYSQL_PS1="(\u@\h) [\d]> "· 使用选项文件
可以在MySQL选项文件中的[mysql]组设置提示,例如根目录中的/etc/my.cnf或.my.cnf文件。例如:
[mysql]prompt=(\\u@\\h) [\\d]>\\_在该例子中,请注意反斜线是双线。如果使用选项文件中的prompt选项来设置提示,当使用特殊提示选项时,建议使用双反斜线。在允许的提示选项和选项文件中可识别的特殊转义序列中有部分重叠。(这些序列列于4.3.2节,“使用选项文件”)。如果使用单反斜线,会遇到问题。例如,\s被解释为空格而不是当前的秒值。下面的例子显示了如何在选项文件中定义提示以包括当前的时间,格式为HH:MM:SS>:
[mysql]prompt="\\r:\\m:\\s> "· 使用命令行选项
可以在mysql的命令行中设置--prompt选项。例如:
shell> mysql --prompt="(\u@\h) [\d]> "(user@host) [database]>· 交互式
你可以使用prompt(或\R)命令交互地更改提示。例如:
mysql> prompt (\u@\h) [\d]>\_PROMPT set to '(\u@\h) [\d]>\_'(user@host) [database]>(user@host) [database]> promptReturning to default PROMPT of mysql>mysql>8.3.3. 怎样从文本文件执行SQL语句
mysql客户程序一般交互使用:
shell> mysql db_name还可以将SQL语句放到一个文件中然后告诉mysql从该文件读取输入。要想实现,创建一个文本文件text_file,并包含你想要执行的语句。然后按如下所示调用mysql:
shell> mysql db_name < text_file还可以用一个USE db_name语句启动文本文件。在这种情况下,不需要在命令行中指定数据库名:
shell> mysql < text_file如果正运行mysql,可以使用source或\.命令执行SQL脚本文件:
mysql> source filenamemysql> \. filename有时想要使用脚本来向用户显示进度信息;为此可以插入下述行:
SELECT '<info_to_display>' AS ' ';将输出<info_to_display>。
关于批处理模式的详细信息,参见3.5节,“在批处理模式下使用mysql”。
8.3.4. mysql技巧
8.3.4.1. 垂直显示查询结果
8.3.4.2. 使用--safe-updates选项
8.3.4.3. 禁用mysql自动连接
该节描述了可以帮助你更有效使用mysql的一些技术。
8.3.4.1. 垂直显示查询结果
一些查询结果如果垂直显示而不用通常的水平表格式显示,则更容易读取。用\G而不用分号结束查询可以垂直显示查询。例如,包括新行的更长的文本值垂直输出时通常更容易读取:
mysql> SELECT * FROM mails WHERE LENGTH(txt) < 300 LIMIT 300,1\G
*************************** 1. row ***************************
msg_nro: 3068
date: 2000-03-01 23:29:50
time_zone: +0200
mail_from: Monty
reply: monty@no.spam.com
mail_to: "Thimble Smith" <tim@no.spam.com>
sbj: UTF-8
txt: >>>>> "Thimble" == Thimble Smith writes:
Thimble> Hi. I think this is a good idea. Is anyone familiar
Thimble> with UTF-8 or Unicode? Otherwise, I'll put this on my
Thimble> TODO list and see what happens.
Yes, please do that.
Regards,
Monty
file: inbox-jani-1
hash: 190402944
1 row in set (0.09 sec)
8.3.4.2. 使用--safe-updates选项
对于新手,有一个有用的启动选项--safe-updates(或--i-am-a-dummy,具有相同的效果)。当你已经发出一个DELETE FROM tbl_name语句但忘记了WHERE子句时很有用。通常情况,这样的语句从表中删除所有行。用--safe-updates,可以通过指定可以识别它们的键值只删除某些行。这样可以帮助防止事故。
若使用--safe-updates选项,mysql连接MySQL服务器时发出下面的语句:
SET SQL_SAFE_UPDATES=1,SQL_SELECT_LIMIT=1000, SQL_MAX_JOIN_SIZE=1000000;参见13.5.3节,“SET语法”。
SET语句有下面的效果:
· 不允许你执行UPDATE或DELETE语句,除非在WHERE子句中指定一个键值约束或提供一个LIMIT子句(或二者皆使用)。例如:
· UPDATE tbl_name SET not_key_column=val WHERE key_column=val;· · UPDATE tbl_name SET not_key_column=val LIMIT 1;· 所有大的SELECT结果自动限制到1,000行,除非语句包括一个LIMIT子句。
· 放弃可能需要检查1,000,000多行组合的多表SELECT语句。
要将限制指定为1,000和1,000,000之外的值,可以使用--select_limit和--max_join_size选项覆盖默认值:
shell> mysql --safe-updates --select_limit=500 --max_join_size=100008.3.4.3. 禁用mysql自动连接
如果mysql客户程序发送查询时断开与服务器的连接,它立即并自动尝试重新连接服务器并再次发送查询。然而,即使mysql重新连接成功,你的第1个连接也已经结束,并且以前的会话对象和设定值被丢失:包括临时表、自动提交模式,以及用户和会话变量。该行为很危险,如下面的例子所示,服务器将在你不知道的情况下关闭并重启:
mysql> SET @a=1;Query OK, 0 rows affected (0.05 sec) mysql> INSERT INTO t VALUES(@a);ERROR 2006: MySQL server has gone awayNo connection. Trying to reconnect...Connection id: 1Current database: test Query OK, 1 row affected (1.30 sec) mysql> SELECT * FROM t;+------+| a |+------+| NULL |+------+1 row in set (0.05 sec)@a用户变量已经随连接丢失,并且重新连接后它也没有定义。如果有必要在连接断开时终止mysql并提示错误,你可以用--skip-reconnect选项启动mysql客户程序。
8.4. mysqlaccess:用于检查访问权限的客户端
mysqlaccess是Yves Carlier为MySQL分发提供的一个诊断工具。它检查访问权限的主机名、用户名和数据库组合。请注意 mysqlaccess检查只使用user、db和host表的访问。它不检查在tables_priv、columns_priv或procs_priv表中指定的表、列或者程序的权限。
调用mysqlaccess的方法:
shell> mysqlaccess [host_name [user_name [db_name]]] [options]mysqlaccess理解下面的选项:
· ---help,-?
显示帮助消息并退出。
· --brief,-b
生成单行表格式的报告。
· --commit
从临时表将新访问权限复制到原授权表。必须为新的权限刷新授权表以使其生效。(例如,执行mysqladmin RELOAD命令)。
· --copy
从原授权表重载临时授权表。
· --db=db_name,-d db_name
指定数据库名。
· ---debug=N
指定调试级别。N可以为从0到3的一个整数。
· --host=host_name,-h host_name
在访问权限中使用的主机名。
· --howto
显示一些例子显示如何使用mysqlaccess。
· --old_server
假定服务器是一个旧版本的MySQL服务器(MySQL 3.21之前),还不知道如何处理全WHERE子句。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果你在命令行中在--password或-p选项后面省略 密码值,将提示你输入密码。
· --plan
显示将来发布的建议和思想。
· --preview
更改临时授权表后显示权限的不同。
· --relnotes
显示发布注解。
· --rhost=host_name,-H host_name
连接给定主机的MySQL服务器。
· --rollback
取消对临时授权表的最新的更改。
· --spassword[=password],-P[password]
以super用户连接服务器时使用的密码。如果在命令行中在--password或-p选项后面省略了 密码值,将提示你输入密码。
· --superuser=user_name,-U user_name
指定以super用户连接时的用户名。
· --tables,-t
生成表格式的报告。
· --user=user_name,-u user_name
在访问权限中使用的主机名。
· --version,-v
显示版本信息并退出。
如果你的MySQL分发安装在某个非标准位置,必须进入mysqlaccess期望找到mysql客户的目录。编辑大约在18行处的mysqlaccess脚本。搜索类似下面的一行:
$MYSQL = '/usr/local/bin/mysql'; # path to mysql executable将路径更改为mysql实际在系统中保存的位置。如果不这样做,当运行mysqlaccess时会发生Broken pipe错误。
8.5. mysqladmin:用于管理MySQL服务器的客户端
mysqladmin是一个执行管理操作的客户程序。可以用它来检查服务器的配置和当前的状态,创建并删除数据库等等。
这样调用mysqladmin:
shell> mysqladmin [options] command [command-options] [command [command-options]] ...mysqladmin支持下面的命令:
· create db_name
创建一个名为db_name的新数据库。
· debug
告诉服务器向错误日志写入调试信息。
· drop db_name
删除名为db_nam的数据库和所有表。
· extended-status
显示服务器状态变量及其值。
· flush-hosts
刷新主机缓存中的所有信息。
· flush-logs
刷新所有日志。
· flush-privileges
重载授权表(类似reload)。
· flush-status
清除状态变量。
· flush-tables
刷新所有表。
· flush-threads
刷新线程缓存。
· kill id,id,...
杀掉服务器线程。
· old-password new-password
类似password但使用旧的(pre-4.1)密码哈希格式保存 密码。(参见5.7.9节,“MySQL 4.1中的密码哈希处理”)。
· password new-password
设置一个新密码。将用mysqladmin连接服务器使用的 账户的密码更改为new-password。
如果new-password包含空格或其它命令解释符的特殊字符,需要用引号将它引起来。在Windows中,一定要使用双引号而不要用单引号;单引号不会从 密码中剥离出来,而是解释为密码的一部分。例如:
shell> mysqladmin password "my new password"
· ping
检查服务器是否仍活动。如果服务器在运行mysqladmin返回状态0,如果不运行返回1。即使出现错误例如Access denied也为0,因为这说明服务器在运行但拒绝了连接,与服务器不在运行不同。
· processlist
显示活动服务器线程的列表。类似SHOW PROCESSLIST语句的输出。如果给出了--verbose选项,输出类似SHOW FULL PROCESSLIST。(参见13.5.4.16节,“SHOW PROCESSLIST语法”)。
· reload
重载授权表。
· refresh
刷新所有表并关闭和打开日志文件。
· shutdown
停止服务器。
· start-slave
开始从服务器上的复制。
· status
显示短服务器状态消息。
· stop-slave
停止从服务器上的复制。
· variables
显示服务器系统变量及其值。
· version
显示服务器的版本信息。
所有命令可以简化为任何唯一的前缀。例如:
shell> mysqladmin proc stat+----+-------+-----------+----+---------+------+-------+------------------+| Id | User | Host | db | Command | Time | State | Info |+----+-------+-----------+----+---------+------+-------+------------------+| 51 | monty | localhost | | Query | 0 | | show processlist |+----+-------+-----------+----+---------+------+-------+------------------+Uptime: 1473624 Threads: 1 Questions: 39487 Slow queries: 0 Opens: 541 Flush tables: 1 Open tables: 19 Queries per second avg: 0.0268 mysqladmin status命令的结果显示下面的值:
· Uptime
MySQL服务器已经运行的秒数。
· Threads
活动线程(客户)的数目。
· Questions
服务器启动以来客户的问题(查询)数目。
· Slow queries
执行时间超过long_query_time秒的查询的数量。参见5.11.4节,“慢速查询日志”。
· Opens
服务器已经打开的数据库表的数量。
· Flush tables
服务器已经执行的flush ...、refresh和reload命令的数量。
· Open tables
目前打开的表的数量。
· Memory in use
mysqld代码直接分配的内存数量。只有用--with--debug=full编译了MySQL该值才显示。
· Maximum memory used
mysqld代码直接分配的最大内存数量。只有用--with--debug=full编译了MySQL该值才显示。
如果当使用Unix套接字文件连接本地服务器时执行mysqladmin shutdown,mysqladmin将等待直到服务器的进程ID文件被删除,以确保服务器正确停止。
mysqladmin支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --character-sets-dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --compress,-C
压缩客户和服务器之间发送的所有信息(如果二者均支持压缩)。
· --count=num,-c num
迭代数目。该选项只有结合--sleep (-i)才能工作。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。 默认为'd:t:o,/tmp/mysqladmin.trace'。
· --default-character-set=charset
使用charsetas作为默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --force,-f
不再为drop database命令进行确认。对于多个命令,即使出现错误也继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --password[=password],-p[password]
连接服务器使用的密码。如果使用短选项形式(-p),该选项和 密码之间不能有空格。如果你在命令行中在--password或-p选项后面省略 密码值,将提示你输入密码。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --relative,-r
当带-I使用时显示当前和前面值的差别。目前,该选项只用于extended-status命令。
· --silent,-s
如果不能建立与服务器的连接则以沉默方式退出。
· --sleep=delay,-i delay
每睡眠delay秒后执行一次命令。
· --socket=path,-S path
用于连接的套接字文件。
· --user=user_name,-u user_name
当连接服务器时使用的MySQL用户名。
· --verbose,-v
冗长模式。打印出程序操作的详细信息。
· --version,-V
显示版本信息并退出。
· --vertical,-E
垂直打印输出。类似于--relative,但垂直打印输出。
· --wait[=count],-w[count]
如果连接不能建立,等待并重试而不是放弃。如果给出一个选项值,则指示重试的次数。默认是一次。
也可以使用--var_name=value选项设置下面的变量:
· connect_timeout
连接超时之前的最大秒数。默认值为43200(12小时)。
· shutdown_timeout
等候关闭的最大秒数。默认值为3600(1小时)。
也可以使用--set-variable=var_name=value或-O var_name=value语法来设置变量。然而,现在不赞成该语法,并且不再使用。
8.6. mysqlbinlog:用于处理二进制日志文件的实用工具
服务器生成的二进制日志文件写成二进制格式。要想检查这些文本格式的文件,应使用mysqlbinlog实用工具。
应这样调用mysqlbinlog:
shell> mysqlbinlog [options] log-files...例如,要想显示二进制日志binlog.000003的内容,使用下面的命令:
shell> mysqlbinlog binlog.0000003输出包括在binlog.000003中包含的所有语句,以及其它信息例如每个语句花费的时间、客户发出的线程ID、发出线程时的时间戳等等。
通常情况,可以使用mysqlbinlog直接读取二进制日志文件并将它们用于本地MySQL服务器。也可以使用--read-from-remote-server选项从远程服务器读取二进制日志。
当读取远程二进制日志时,可以通过连接参数选项来指示如何连接服务器,但它们经常被忽略掉,除非你还指定了--read-from-remote-server选项。这些选项是--host、--password、--port、--protocol、--socket和--user。
还可以使用mysqlbinlog来读取在复制过程中从服务器所写的中继日志文件。中继日志格式与二进制日志文件相同。
在5.11.3节,“二进制日志”中详细讨论了二进制日志。
mysqlbinlog支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· ---database=db_name,-d db_name
只列出该数据库的条目(只用本地日志)。
· --force-read,-f
使用该选项,如果mysqlbinlog读它不能识别的二进制日志事件,它会打印警告,忽略该事件并继续。没有该选项,如果mysqlbinlog读到此类事件则停止。
· --hexdump,-H
在注释中显示日志的十六进制转储。该输出可以帮助复制过程中的调试。在MySQL 5.1.2中添加了该选项。
· --host=host_name,-h host_name
获取给定主机上的MySQL服务器的二进制日志。
· --local-load=path,-l pat
为指定目录中的LOAD DATA INFILE预处理本地临时文件。
· --offset=N,-o N
跳过前N个条目。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。
· --port=port_num,-P port_num
用于连接远程服务器的TCP/IP端口号。
· --position=N,-j N
不赞成使用,应使用--start-position。
· --protocol={TCP | SOCKET | PIPE | -position
使用的连接协议。
· --read-from-remote-server,-R
从MySQL服务器读二进制日志。如果未给出该选项,任何连接参数选项将被忽略。这些选项是--host、--password、--port、--protocol、--socket和--user。
· --result-file=name, -r name
将输出指向给定的文件。
· --short-form,-s
只显示日志中包含的语句,不显示其它信息。
· --socket=path,-S path
用于连接的套接字文件。
· --start-datetime=datetime
从二进制日志中第1个日期时间等于或晚于datetime参量的事件开始读取。datetime值相对于运行mysqlbinlog的机器上的本地时区。该值格式应符合DATETIME或TIMESTAMP数据类型。例如:
shell> mysqlbinlog --start-datetime="2004-12-25 11:25:56" binlog.000003该选项可以帮助点对点恢复。
· --stop-datetime=datetime
从二进制日志中第1个日期时间等于或晚于datetime参量的事件起停止读。关于datetime值的描述参见--start-datetime选项。该选项可以帮助及时恢复。
· --start-position=N
从二进制日志中第1个位置等于N参量时的事件开始读。
· --stop-position=N
从二进制日志中第1个位置等于和大于N参量时的事件起停止读。
· --to-last-logs,-t
在MySQL服务器中请求的二进制日志的结尾处不停止,而是继续打印直到最后一个二进制日志的结尾。如果将输出发送给同一台MySQL服务器,会导致无限循环。该选项要求--read-from-remote-server。
· --disable-logs-bin,-D
禁用二进制日志。如果使用--to-last-logs选项将输出发送给同一台MySQL服务器,可以避免无限循环。该选项在崩溃恢复时也很有用,可以避免复制已经记录的语句。注释:该选项要求有SUPER权限。
· --user=user_name,-u user_name
连接远程服务器时使用的MySQL用户名。
· --version,-V
显示版本信息并退出。
还可以使用--var_name=value选项设置下面的变量:
· open_files_limit
指定要保留的打开的文件描述符的数量。
可以将mysqlbinlog的输出传到mysql客户端以执行包含在二进制日志中的语句。如果你有一个旧的备份,该选项在崩溃恢复时也很有用(参见5.9.1节,“数据库备份”):
shell> mysqlbinlog hostname-bin.000001 | mysql或:
shell> mysqlbinlog hostname-bin.[0-9]* | mysql如果你需要先修改含语句的日志,还可以将mysqlbinlog的输出重新指向一个文本文件。(例如,想删除由于某种原因而不想执行的语句)。编辑好文件后,将它输入到mysql程序并执行它包含的语句。
mysqlbinlog有一个--position选项,只打印那些在二进制日志中的偏移量大于或等于某个给定位置的语句(给出的位置必须匹配一个事件的开始)。它还有在看见给定日期和时间的事件后停止或启动的选项。这样可以使用--stop-datetime选项进行点对点恢复(例如,能够说“将数据库前滚动到今天10:30 AM的位置”)。
如果MySQL服务器上有多个要执行的二进制日志,安全的方法是在一个连接中处理它们。下面是一个说明什么是不安全的例子:
shell> mysqlbinlog hostname-bin.000001 | mysql # DANGER!!shell> mysqlbinlog hostname-bin.000002 | mysql # DANGER!!使用与服务器的不同连接来处理二进制日志时,如果第1个日志文件包含一个CREATE TEMPORARY TABLE语句,第2个日志包含一个使用该临时表的语句,则会造成问题。当第1个mysql进程结束时,服务器撤销临时表。当第2个mysql进程想使用该表时,服务器报告 “不知道该表”。
要想避免此类问题,使用一个连接来执行想要处理的所有二进制日志中的内容。下面提供了一种方法:
shell> mysqlbinlog hostname-bin.000001 hostname-bin.000002 | mysql另一个方法是:
shell> mysqlbinlog hostname-bin.000001 > /tmp/statements.sqlshell> mysqlbinlog hostname-bin.000002 >> /tmp/statements.sqlshell> mysql -e "source /tmp/statements.sql"mysqlbinlog产生的输出可以不需要原数据文件即可重新生成一个LOAD DATA INFILE操作。mysqlbinlog将数据复制到一个临时文件并写一个引用该文件的LOAD DATA LOCAL INFILE语句。由系统确定写入这些文件的目录的默认位置。要想显式指定一个目录,使用--local-load选项。
因为mysqlbinlog可以将LOAD DATA INFILE语句转换为LOAD DATA LOCAL INFILE语句(也就是说,它添加了LOCAL),用于处理语句的客户端和服务器必须配置为允许LOCAL操作。参见5.6.4节,“LOAD DATA LOCAL安全问题”。
警告:为LOAD DATA LOCAL语句创建的临时文件不会自动删除,因为在实际执行完那些语句前需要它们。不再需要语句日志后应自己删除临时文件。文件位于临时文件目录中,文件名类似original_file_name-#-#。
--hexdump选项可以在注释中产生日志内容的十六进制转储:
shell> mysqlbinlog --hexdump master-bin.000001上述命令的输出应类似:
/*!40019 SET @@session.max_insert_delayed_threads=0*/;/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;# at 4#051024 17:24:13 server id 1 end_log_pos 98# Position Timestamp Type Master ID Size Master Pos Flags# 00000004 9d fc 5c 43 0f 01 00 00 00 5e 00 00 00 62 00 00 00 00 00# 00000017 04 00 35 2e 30 2e 31 35 2d 64 65 62 75 67 2d 6c |..5.0.15.debug.l|# 00000027 6f 67 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |og..............|# 00000037 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|# 00000047 00 00 00 00 9d fc 5c 43 13 38 0d 00 08 00 12 00 |.......C.8......|# 00000057 04 04 04 04 12 00 00 4b 00 04 1a |.......K...|# Start: binlog v 4, server v 5.0.15-debug-log created 051024 17:24:13# at startupROLLBACK;十六进制转储的输出包含下面的元素:
· Position: The byte position within the log file.
· Timestamp: The event timestamp. In the example just shown, '9d fc 5c 43' is the representation of '051024 17:24:13' in hexadecimal.
· Type: The type of the log event. '0f' means that the example event is a FORMAT_DESCRIPTION_EVENT. The types are:
· 00 UNKNOWN_EVENT· This event should never be present in the log.· 01 START_EVENT_V3· This indicates the start of a log file written by MySQL 4 or earlier.· 02 QUERY_EVENT· The most common type of events. These contain queries executed· on the master.· 03 STOP_EVENT· Indicates that master has stopped.· 04 ROTATE_EVENT· Written when the master switches to a new log file.· 05 INTVAR_EVENT· Used mainly for AUTO_INCREMENT values and if the LAST_INSERT_ID()· function is used in the statement.· 06 LOAD_EVENT· Used for LOAD DATA INFILE in MySQL 3.23.· 07 SLAVE_EVENT· Reserved for future use.· 08 CREATE_FILE_EVENT· Used for LOAD DATA INFILE statements. This indicates the start· of execution of such a statement. A temporary file is created· on the slave. Used in MySQL 4 only.· 09 APPEND_BLOCK_EVENT· Contains data for use in a LOAD DATA INFILE statement. The· data is stored in the temporary file on the slave.· 0a EXEC_LOAD_EVENT· Used for LOAD DATA INFILE statements. The contents of the· temporary file is stored in the table on the slave.· Used in MySQL 4 only.· 0b DELETE_FILE_EVENT· Rollback of LOAD DATA INFILE statement. The temporary file· should be deleted on slave.· 0c NEW_LOAD_EVENT· Used for LOAD DATA INFILE in MySQL 4 and earlier.· 0d RAND_EVENT· Used to send information about random values if the RAND()· function is used in the query.· 0e USER_VAR_EVENT· Used to replicate user variables.· 0f FORMAT_DESCRIPTION_EVENT· This indicates the start of a log file written by MySQL 5 or later.· 10 XID_EVENT· Event indicating commit of XA transaction· 11 BEGIN_LOAD_QUERY_EVENT· Used for LOAD DATA statements in MySQL 5 and later.· 12 EXECUTE_LOAD_QUERY_EVENT· Used for LOAD DATA statements in MySQL 5 and later.· 13 TABLE_MAP_EVENT· Reserved for future use· 14 WRITE_ROWS_EVENT· Reserved for future use· 15 UPDATE_ROWS_EVENT· Reserved for future use· 16 DELETE_ROWS_EVENT· Reserved for future use· Master ID: The server id of the master that created the event.
· Size: The size in bytes of the event.
· Master Pos: The position of the event in the original master log file.
· Flags: 16 flags.
· 01 LOG_EVENT_BINLOG_IN_USE_F· Log file correctly closed (Used only in FORMAT_DESCRIPTION_EVENT)· If this flag is set (if the flags are e.g. '01 00') in an· FORMAT_DESCRIPTION_EVENT, then the log file has not been· properly closed. Most probably because of a master crash (for· example, due to power failure).· 02 Reserved for future use.· 04 LOG_EVENT_THREAD_SPECIFIC_F· Set if the event is dependent on the connection it was· executed in (example '04 00'), e.g. if the event uses· temporary tables.· 08 LOG_EVENT_SUPPRESS_USE_F· Set in some circumstances when the event is not dependent on· the current database其它标志保留用于将来使用。
在以后的版本中十六进制转储输出的格式可能会改变。
8.7. mysqlcheck:表维护和维修程序
mysqlcheck客户端可以检查和修复MyISAM表。它还可以优化和分析表。
mysqlcheck的功能类似myisamchk,但其工作不同。主要差别是当mysqld服务器在运行时必须使用mysqlcheck,而myisamchk应用于服务器没有运行时。使用mysqlcheck的好处是不需要停止服务器来检查或修复表。
Mysqlcheck为用户提供了一种方便的使用SQL语句CHECK TABLE、REPAIR TABLE、ANALYZE TABLE和OPTIMIZE TABLE的方式。它确定在要执行的操作中使用使用哪个语句,然后将语句发送到要执行的服务器上。
有3种方式来调用mysqlcheck:
shell> mysqlcheck[options] db_name [tables]shell> mysqlcheck[options] ---database DB1 [DB2 DB3...]shell> mysqlcheck[options] --all--database如果没有指定任何表或使用---database或--all--database选项,则检查整个数据库。
同其它客户端比较,mysqlcheck有一个特殊特性。重新命名二进制可以更改检查表的默认行为(--check)。如果你想要一个工具默认可以修复表的工具,只需要将mysqlcheck重新复制为mysqlrepair,或者使用一个符号链接mysqlrepair链接mysqlcheck。如果调用mysqlrepair,可按照命令修复表。
下面的名可用来更改mysqlcheck的默认行为:
mysqlrepair
默认选项为--repair
mysqlanalyze
默认选项为--analyze
mysqloptimize
默认选项为--optimize
mysqlcheck支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --all--database,-A
检查所有数据库中的所有表。与使用---database选项相同,在命令行中命名所有数据库。
· --all-in-1,-1
不是为每个表发出一个语句,而是为命名数据库中待处理的所有表的每个数据库执行一个语句。
· --analyze,-a
分析表。
· --auto-repair
如果某个被检查的表破坏了,自动修复它。检查完所有表后自动进行所有需要的修复。
· --character-sets-dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --check,-c
检查表的错误。
· --check-only-changed,-C
只检查上次检查以来已经更改的或没有正确关闭的表。
· --compress
压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。
· ---database,-B
处理数据库中命名的所有表。使用该选项,所有字名参量被看作数据库名,而不是表名。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。
· --default-character-set=charset
使用charsetas默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --extended,-e
如果你正使用该选项来检查表,可以确保它们100%地一致,但需要很长的时间。
如果你正使用该选项来修复表,则运行扩展修复,不但执行的时间很长,而且还会产生大量的垃圾行!
· --fast,-F
只检查没有正确关闭的表。
· --force,-f
即使出现SQL错误也继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --medium-check,-m
执行比--extended操作更快的检查。只能发现99.99%的错误,在大多数情况下这已经足够了。
· --optimize,-o
优化表。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --quick,-q
如果你正使用该选项在检查表,它防止扫描行以检查错误链接的检查。这是最快的检查方法。
如果你正使用该选项在修复表,它尝试只修复索引树。这是最快的修复方法。
· --repair,-r
执行可以修复大部分问题的修复,只是唯一值不唯一时不能修复。
· --silent,-s
沉默模式。只打印错误消息。
· --socket=path,-S path
用于连接的套接字文件。
· --tables
覆盖---database或-B选项。选项后面的所有参量被视为表名。
· --user=user_name,-u user_name
当连接服务器时使用的MySQL用户名。
· --verbose
目录
8.1. 客户端脚本和实用工具概述
8.2. myisampack:生成压缩、只读MyISAM表
8.3. mysql:MySQL命令行工具
8.3.1. 选项
8.3.2. mysql命令
8.3.3. 怎样从文本文件执行SQL语句
8.3.4. mysql技巧
8.4. mysqlaccess:用于检查访问权限的客户端
8.5. mysqladmin:用于管理MySQL服务器的客户端
8.6. mysqlbinlog:用于处理二进制日志文件的实用工具
8.7. mysqlcheck:表维护和维修程序
8.8. mysqldump:数据库备份程序
8.9. mysqlhotcopy:数据库备份程序
8.10. mysqlimport:数据导入程序
8.11. mysqlshow-显示数据库、表和列信息
8.12. myisamlog:显示MyISAM日志文件内容
8.13. perror:解释错误代码
8.14. replace:字符串替换实用工具
8.15. mysql_zap:杀死符合某一模式的进程
有许多不同的MySQL客户端程序可以连接服务器以访问数据库或执行管理任务。也可以使用其它工具。这些程序不与服务器进行通讯但可以执行MySQL相关的操作。
本章简述了这些程序然后详细描述了每个程序。描述了如何调用这些程序和它们理解的选项。调用程序和指定程序选项的总信息参见第4章:MySQL程序概述。
8.1. 客户端脚本和实用工具概述
下面简单列出了MySQL客户端程序和实用工具:
· myisampack
压缩MyISAM表以产生更小的只读表的一个工具。参见8.2节,“myisampack:生成压缩、只读MyISAM表”。
· mysql
交互式输入SQL语句或从文件以批处理模式执行它们的命令行工具。参见8.3节,“mysql:MySQL命令行工具”。
· mysqlaccess
检查访问主机名、用户名和数据库组合的权限的脚本。
· mysqladmin
执行管理操作的客户程序,例如创建或删除数据库,重载授权表,将表刷新到硬盘上,以及重新打开日志文件。mysqladmin还可以用来检索版本、进程,以及服务器的状态信息。参见8.5节,“mysqladmin:用于管理MySQL服务器的客户端”。
· mysqlbinlog
从二进制日志读取语句的工具。在二进制日志文件中包含的执行过的语句的日志可用来帮助从崩溃中恢复。参见8.6节,“mysqlbinlog:用于处理二进制日志文件的实用工具”。
· mysqlcheck
检查、修复、分析以及优化表的表维护客户程序。参见8.7节,“mysqlcheck:表维护和维修程序”。
· mysqldump
将MySQL数据库转储到一个文件(例如SQL语句或tab分隔符文本文件)的客户程序。增强版免费软件首先由Igor Romanenko提供。参见8.8节,“mysqldump:数据库备份程序”。
· mysqlhotcopy
当服务器在运行时,快速备份MyISAM或ISAM表的工具。参见8.9节,“mysqlhotcopy:数据库备份程序”。
· mysql import
使用LOAD DATA INFILE将文本文件导入相关表的客户程序。参见8.10节,“mysqlimport:数据导入程序”。
· mysqlshow
显示数据库、表、列以及索引相关信息的客户程序。参见8.11节,“mysqlshow:显示数据库、表和列信息”。
· perror
显示系统或MySQL错误代码含义的工具。参见8.13节,“perror:解释错误代码”。
· replace
更改文件中或标准输入中的字符串的实用工具。参见8.14节,“replace:字符串替换实用工具”。
MySQL AB还提供了大量GUI工具用于管理和MySQL服务器的其它工作。相关基本信息参见第4章:MySQL程序概述。
每个MySQL程序有许多不同的选项。但每个MySQL程序均提供一个---help选项,可以用来全面描述程序不同的选项。例如,可以试试mysql---help。
使用mysqlclient库同服务器进行通讯的MySQL客户使用下面的环境变量:
MYSQL_UNIX_PORT
默认Unix套接字文件;用于连接localhost
MYSQL_TCP_PORT
默认端口号;用于TCP/IP连接
MYSQL_PWD
默认密码
MYSQL_DEBUG
调试过程中的调试跟踪选项
TMPDIR
创建临时表和文件的目录
使用MYSQL_PWD不安全。参见5.8.6节,“使你的密码安全”。
可以在选项文件中或在命令行中指定选项来替换所有标准程序的默认选项值或指定的环境变量的值。参见4.3节,“指定程序选项”。
8.2. myisampack:生成压缩、只读MyISAM表
myisampack工具可以压缩MyISAM表.MYIsampack分别压缩表中的每一列。通常,myisampack可以将数据文件压缩到40%-70%。
当以后使用表时,解压缩列需要的信息被读入内存。当访问具体的记录时性能会更好,因为你只需要解压缩一个记录。
MySQL使用mmap()对压缩的表进行内存映射。如果mmap()不工作,MySQL返回到普通读/写文件操作。
请注意:
· 如果用--skip-external-locking选项调用mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好注意。
· 表压缩后,它变为只读。这是故意的(例如当访问CD上的压缩的表时)。允许写入到压缩的表位于我们的TODO列表中,但优先级较低。
· myisampack可以压缩BLOB或TEXT列。旧版本ISAM表的pack_isam程序不可以。
调用myisampack的方法:
shell> myisampack [options] filename ...文件名应为索引(.MYI)文件的文件名。如果不在数据库目录,应指定文件的路径名。允许忽略.MYI扩展名。
myisampack支持下面的选项:
· --help,-?
显示帮助消息并退出。
· --backup,-b
使用tbl_name.OLD名备份表数据文件。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。
· --force,-f
产生一个压缩的表,即使它比原始表大,或如果以前调用myisampack的中间文件存在。(myisampack压缩表时在数据库目录中创建一个名为tbl_name.TMD的中间文件。如果杀掉myisampack,.TMD文件会被删除)。通常情况,如果myisampack发现tbl_name.TMD存在则退出并提示错误。用--force,myisampack则一定压缩表。
· -join=big_tbl_name,-j big_tbl_name
将命令行中的所有表联接为一个表big_tbl_name。将要连接的所有表必须有相等的结构(相同的列名和类型,相同的索引等等)。
· --pack length=len,-p len
指定记录长度存储大小,以字节计。值应为1、2或者3。myisampack保存所有长度指针为1、2或者3字节的行。在大多数正常情况下,myisampack在开始压缩文件前可以确定准确的长度值,但在压缩过程中它可以提示它可能已经使用了一个短的长度。在这种情况下,myisampack输出一条提示,下次你压缩同一文件时,你可以使用更短的记录长度。
· --silent,-s
沉默模式。只有发生错误时才写输出。
· --test,-t
没有实际地压缩表,只是测试压缩。
· --tmpdir=path,-T path
使用myisamchk创建临时文件的目录。
· --verbose,-v
冗长模式。写压缩操作过程相关信息和其结果。
· --version,-V
显示版本信息并退出。
· --wait,-w
如果表正使用则等待并重试。如果用--skip-external-locking选项调用了mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好注意。
下面的顺序命令说明了典型的表压缩会话:
shell> ls -l station.*-rw-rw-r-- 1 monty my 994128 Apr 17 19:00 station.MYD-rw-rw-r-- 1 monty my 53248 Apr 17 19:00 station.MYI-rw-rw-r-- 1 monty my 5767 Apr 17 19:00 station.frm shell> myisamchk -dvv station MyISAM file: stationIsam-version: 2Creation time: 1996-03-13 10:08:58Recover time: 1997-02-02 3:06:43Data records: 1192 Deleted blocks: 0Datafile parts: 1192 Deleted data: 0Datafile pointer (bytes): 2 Keyfile pointer (bytes): 2Max datafile length: 54657023 Max keyfile length: 33554431Recordlength: 834Record format: Fixed length table description:Key Start Len Index Type Root Blocksize Rec/key1 2 4 unique unsigned long 1024 1024 12 32 30 multip. text 10240 1024 1 Field Start Length Type1 1 12 2 43 6 44 10 15 11 206 31 17 32 308 62 359 97 3510 132 3511 167 412 171 1613 187 3514 222 415 226 1616 242 2017 262 2018 282 2019 302 3020 332 421 336 422 340 123 341 824 349 825 357 826 365 227 367 228 369 429 373 430 377 131 378 232 380 833 388 434 392 435 396 436 400 437 404 138 405 439 409 440 413 441 417 442 421 443 425 444 429 2045 449 3046 479 147 480 148 481 7949 560 7950 639 7951 718 7952 797 853 805 154 806 155 807 2056 827 457 831 4 shell> myisampack station.MYICompressing station.MYI: (1192 records)- Calculating statistics normal: 20 empty-space: 16 empty-zero: 12 empty-fill: 11pre-space: 0 end-space: 12 table-lookups: 5 zero: 7Original trees: 57 After join: 17- Compressing file87.14%Remember to run myisamchk -rq on compressed tables shell> ls -l station.*-rw-rw-r-- 1 monty my 127874 Apr 17 19:00 station.MYD-rw-rw-r-- 1 monty my 55296 Apr 17 19:04 station.MYI-rw-rw-r-- 1 monty my 5767 Apr 17 19:00 station.frm shell> myisamchk -dvv station MyISAM file: stationIsam-version: 2Creation time: 1996-03-13 10:08:58Recover time: 1997-04-17 19:04:26Data records: 1192 Deleted blocks: 0Datafile parts: 1192 Deleted data: 0Datafile pointer (bytes): 3 Keyfile pointer (bytes): 1Max datafile length: 16777215 Max keyfile length: 131071Recordlength: 834Record format: Compressed table description:Key Start Len Index Type Root Blocksize Rec/key1 2 4 unique unsigned long 10240 1024 12 32 30 multip. text 54272 1024 1 Field Start Length Type Huff tree Bits1 1 1 constant 1 02 2 4 zerofill(1) 2 93 6 4 no zeros, zerofill(1) 2 94 10 1 3 95 11 20 table-lookup 4 06 31 1 3 97 32 30 no endspace, not_always 5 98 62 35 no endspace, not_always, no empty 6 99 97 35 no empty 7 910 132 35 no endspace, not_always, no empty 6 911 167 4 zerofill(1) 2 912 171 16 no endspace, not_always, no empty 5 913 187 35 no endspace, not_always, no empty 6 914 222 4 zerofill(1) 2 915 226 16 no endspace, not_always, no empty 5 916 242 20 no endspace, not_always 8 917 262 20 no endspace, no empty 8 918 282 20 no endspace, no empty 5 919 302 30 no endspace, no empty 6 920 332 4 always zero 2 921 336 4 always zero 2 922 340 1 3 923 341 8 table-lookup 9 024 349 8 table-lookup 10 025 357 8 always zero 2 926 365 2 2 927 367 2 no zeros, zerofill(1) 2 928 369 4 no zeros, zerofill(1) 2 929 373 4 table-lookup 11 030 377 1 3 931 378 2 no zeros, zerofill(1) 2 932 380 8 no zeros 2 933 388 4 always zero 2 934 392 4 table-lookup 12 035 396 4 no zeros, zerofill(1) 13 936 400 4 no zeros, zerofill(1) 2 937 404 1 2 938 405 4 no zeros 2 939 409 4 always zero 2 940 413 4 no zeros 2 941 417 4 always zero 2 942 421 4 no zeros 2 943 425 4 always zero 2 944 429 20 no empty 3 945 449 30 no empty 3 946 479 1 14 447 480 1 14 448 481 79 no endspace, no empty 15 949 560 79 no empty 2 950 639 79 no empty 2 951 718 79 no endspace 16 952 797 8 no empty 2 953 805 1 17 154 806 1 3 955 807 20 no empty 3 956 827 4 no zeros, zerofill(2) 2 957 831 4 no zeros, zerofill(1) 2 9myisampack显示下面的各种信息:
· normal
不需要进行额外压缩的列的数量。
· empty-space
只包含空格的列的数量;占一个比特。
· empty-zero
只包含二进制零的列的数量;占一个比特。
· empty-fill
不占该类全字节范围的整数列的数量;这些列被改为较小的类型。例如,如果所有值的范围为从-128到127,BIGINT列(8个字节)可以保存为TINYINT列(1个字节)。
· pre-space
用引导空格保存的十进制列的数量。在这种情况下,每个值包含一个引导空格的数量计数。
· end-space
有大量结尾空格的列的数量。在这种情况下,每个值包含一个结尾空格的数量计数。
· table-lookup
该列只有少量的不同的值,在进行哈夫曼压缩前被转换为一个ENUM。
· zero
所有值为零的列的数量。
· Original trees
哈夫曼树的最初数量。
· After join
联接树以节省一些头空间之后留下的哈夫曼树的数量。
表被压缩后,myisamchk -dvv为每列输出详细信息:
· Type
列的类型。该值可以包含下面的任何描述符:
o constant
所有行具有相同的值。
o no endspace
不保存结尾空格。
o no endspace,not_always
不保存结尾空格并且对于所有的值不压缩结尾空格。
o no endspace,no empty
不保存结尾空格。不保存空值。
o table-lookup
列被转换为一个ENUM。
o zerofill(n)
值中最有意义的n字节总为0,并且不保存。
o no zeros
不保存零。
o always zeros
用一个位保存零值。
· Huff tree
列相关的哈夫曼树的数量。
· Bits
哈夫曼树使用的位数。
运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作:
shell> myisamchk -rq --sort-index --analyze tbl_name.MYI将压缩的表安装到MySQL数据库目录中后,应执行mysqladmin flush-tables以强制mysqld使用新的表。
要想解压缩一个压缩的表,使用myisamchk或isamchk的--unpack选项。
8.3. mysql:MySQL命令行工具
8.3.1. 选项
8.3.2. mysql命令
8.3.3. 怎样从文本文件执行SQL语句
8.3.4. mysql技巧
mysql是一个简单的SQL外壳(有GNU readline功能)。它支持交互式和非交互式使用。当交互使用时,查询结果采用ASCII表格式。当采用非交互式(例如,用作过滤器)模式时,结果为tab分割符格式。可以使用命令行选项更改输出格式。
如果由于结果较大而内存不足遇到问题,使用--quick选项。这样可以强制mysql从服务器每次一行搜索结果,而不是检索整个结果集并在显示之前不得不将它保存到内存中。使用mysql_use_result()而不是mysql_store_result()来搜索结果集。
使用mysql很简单。从命令解释符提示来调用它:
shell> mysql db_name或:
shell> mysql --user=user_name --password=your_password db_name这样输入一个SQL语句,用‘;’、\g或者\G结尾并按回车键。
你可以这样运行一个脚本:
shell> mysql db_name < script.sql > output.tab8.3.1. 选项
mysql支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --batch,-B
打印结果,使用tab作为列间隔符,每个行占用新的一行。使用该选项,则mysql不使用历史文件。
· --character-sets -dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --compress,-C
压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。
· ---database=db_name,-D db_name
要使用的数据库。主要在选项文件中有用。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。 默认为'd:t:o,/tmp/mysql.trace'。
· ---debug-info,-T
当程序退出时输出部分调试信息。
· --default-character-set=charset
使用charsetas作为默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --execute=statement, -e statement
执行语句并退出。默认输出格式与用--batch产生的相同。4.3.1节,“在命令行上使用选项”中提供了一些例子。
· --force,-f
即使出现一个SQL错误仍继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --html,-H
产生HTML输出。
· --ignore-space,-i
忽视函数名后面的空格。其结果描述参见5.3.2节,“SQL服务器模式”中的IGNORE_SPACE的讨论。
· --local-infile[={0|1}]
为LOAD DATA INFILE启用或禁用LOCAL功能。没有值,该选项启用LOCAL。还可以采用--local-infile=0或--local-infile=1以显式禁用或启用LOCAL。如果服务器不支持,启用LOCAL不会生效。
· --named-commands,-G
命名的命令被启用。允许长格式命令和短格式\*命令。例如,quit和\q均被识别。
· --no-auto-rehash,-A
不自动重新进行哈希运算。该选项使mysql启动得更快,但果你想要完成表和列名,你必须发出rehash命令。
· --no-beep,-b
当发生错误时不要保持。
· --no-named-commands,-g
命名的命令被禁用。只使用\*形式,或者只使用行开头的命名用分号(‘;’)结束的的命令。对于MySQL 3.23.22,默认情况mysql启动时启用该选项。然而,即使使用该选项,长格式命令仍然从第1行工作。
· --no-pager
不使用分页器来显示查询输出。在8.3.2节,“mysql命令”中详细讨论了输出分页。
· --no-tee
不将输出复制到文件中。在8.3.2节,“mysql命令”中详细讨论了Tee文件。
· --one--database,-O
忽视除了为命令行中命名的默认数据库的语句。可以帮助跳过对二进制日志中的其它数据库的更新。
· --pager[=command]
使用给出的命令来分页查询输出。如果该命令被删除,默认分页器为PAGER环境变量的值。合法pagers是less、more、cat [>filename]等等。该选项只在Unix中工作。不能以批处理模式工作。在8.3.2节,“mysql命令”中详细讨论了输出分页。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。在SysV-based UNIX系统中应省略密码,因为密码可以显示在ps的输出中。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --prompt=format_str
将提示设置为指定的格式。默认为mysql>。在8.3.2节,“mysql命令”中描述了提示中可以包含的具体顺序。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --quick,-q
不缓存每个查询的结果,按照接收顺序打印每一行。如果输出被挂起,服务器会慢下来。使用该选项,mysql不使用历史文件。
· --raw,-r
写列的值而不转义转换。通常结合--batch选项使用。
· --reconnect
如果与服务器之间的连接断开,自动尝试重新连接。每次连接断开后则尝试一次重新连接。要想禁止重新连接,使用--skip-reconnect。
· --safe-updates,--i-am-a-dummy,-U
只允许那些使用键值指定行生效的UPDATE和DELETE语句。如果已经在选项文件中设置了该选项,可以用命令行中的--safe-updates覆盖它。关于该选项的详细信息参见8.3.4节,“mysql技巧”。
· --secure-auth
不向旧(pre-4.1.1)格式的服务器发送密码。这样可以防止不使用新密码格式的服务器的连接。
· --show-warnings
如果每个语句后有警告则显示。该选项适用于交互式和批处理模式。
· --sigint-ignore
忽视SIGINT符号(一般为Control-C的结果)。
· --silent,-s
沉默模式。产生少的输出。可以多次使用该选项以产生更少的输出。
· --skip-column-names,-N
在结果中不写列名。
· --skip-line-numbers,-L
在错误信息中不写行号。当你想要比较包括错误消息的结果文件时有用。
· --socket=path,-S path
用于连接的套接字文件。
· --tables,-t
用表格式显示输出。这是交互式应用的默认设置,但可用来以批处理模式产生表输出。
· --tee=file_name
将输出拷贝添加到给定的文件中。该选项在批处理模式不工作。在8.3.2节,“mysql命令”中详细讨论了Tee文件。
· --unbuffered,-n
每次查询后刷新缓存区。
· --user=user_name,-u user_name
当连接服务器时MySQL使用的用户名。
· --verbose,-v
冗长模式。产生更多的输出。可以多次使用该选项以产生更多的输出。(例如,-v -v -v甚至可以在批处理模式产生表输出格式)。
· --version,-V
显示版本信息并退出。
· --vertical,-E
垂直输出查询输出的行。没有该选项,可以用\G结尾来指定单个语句的垂直输出。
· --wait,-w
如果不能建立连接,等待并重试而不是放弃。
· --xml,-X
产生XML输出。
你还可以使用--var_name=value选项设置下面的变量:
· connect_timeout
连接超时前的秒数。(默认值是0)。
· max_allowed_packet
从服务器发送或接收的最大包长度。(默认值是16MB)。
· max_join_size
当使用--safe-updates时联接中的行的自动限制。(默认值是1,000,000)。
· net_buffer_length
TCP/IP和套接字通信缓冲区大小。(默认值是16KB)。
· select_limit
当使用--safe-updates时SELECT语句的自动限制。(默认值是1,000)。
也可以使用--set-variable=var_name=value or -O var_name=value语法来设置变量。不赞成使用该语法。
在Unix中,mysql客户程序向历史文件中写入已执行语句的一条记录。默认情况,历史文件名为.mysql_history并在根目录中重建。要想指定不同的文件,应设置MYSQL_HISTFILE环境变量的值。
如果不想要历史文件,首先删除.mysql_history(如果有),然后使用下面的任何一种方法:
· 将MYSQL_HISTFILE变量设到/dev/null。要想在每次登录时让该设置生效,将该设置放入外壳的一个启动文件中。
· 创建.mysql_history,作为一个符号链接指向/dev/null:
· shell> ln -s /dev/null $HOME/.mysql_history只需要执行一次。
8.3.2. mysql命令
mysql将发出的SQL语句发送到待执行的服务器。还有一系列命令mysql可以自己解释。要查看这些命令,在mysql>提示下输入help或\h:
mysql> help
List of all MySQL commands:
Note that all text commands must be first on line and end with ';'
? (\?) Synonym for `help'.
clear (\c) Clear command.
connect (\r) Reconnect to the server. Optional arguments are db and host.
delimiter (\d) Set statement delimiter. NOTE: Takes the rest of the line as new delimiter.
edit (\e) Edit command with $EDITOR.
ego (\G) Send command to mysql server, display result vertically.
exit (\q) Exit mysql. Same as quit.
go (\g) Send command to mysql server.
help (\h) Display this help.
nopager (\n) Disable pager, print to stdout.
notee (\t) Don't write into outfile.
pager (\P) Set PAGER [to_pager]. Print the query results via PAGER.
print (\p) Print current command.
prompt (\R) Change your mysql prompt.
quit (\q) Quit mysql.
rehash (\#) Rebuild completion hash.
source (\.) Execute a SQL script file. Takes a file name as an argument.
status (\s) Get status information from the server.
system (\!) Execute a system shell command.
tee (\T) Set outfile [to_outfile]. Append everything into given outfile.
use (\u) Use another database. Takes database name as argument.
warnings (\W) Show warnings after every statement.
nowarning (\w) Don't show warnings after every statement.
每个命令有长形式和短形式。长形式对大小写不敏感;短形式敏感。长形式后面可以加一个分号结束符,但短形式不可以。
在delimiter命令中,应避免使用反斜线(‘\’),因为这是MySQL的转义符。
Edit、nopager、pager和system命令只在Unix中工作。
status命令提供连接和使用的服务器相关的部分信息。如果用--safe-updates模式运行,status也打印影响查询的MySQL变量的值。
要想记录查询及其输出,应使用tee命令。屏幕上显示的所有数据被追加到给定的文件后面。这对于调试也很有用。可以用--tee选项在命令行中启用该特性,或者用tee命令交互式启用。可以用notee命令交互式禁用tee文件。再次执行tee可以重新启用日志。前面的文件使用时不带任何参数。请注意执行完每个语句后tee可以将查询结果刷新到一个文件中,并且在mysql打印下一个提示前刷新。
用--pager选项,可以用交互式模式使用Unix程序,例如less、more或者其它类似的程序,来浏览或搜索查询结果。如果未指定该选项的值,mysql检查PAGER环境变量的值并将PAGER设为该值。可以用pager命令交互式启用输出分页,并用nopager禁用。该命令采用可选参量;如果给出,分页程序设置为该值。如果没有给出参量,分页器被设置为在命令行中设置的分页器的值,如果未指定分页器,则设置为stdout。
输出分页只适合Unix,因为它使用popen()函数,该函数在Windows中不存在。在Windows中,可以使用tee选项来保存查询输出,尽管在某些情况下浏览输出时不如pager方便。
关于pager命令的一些技巧:
· 可以使用它写入一个文件,将结果只输出到该文件中:
· mysql> pager cat > /tmp/log.txt也可以为将用作分页器的程序传递选项:
mysql> pager less -n -i -S· 注意前面例子中的-S选项。它可以帮助浏览广范围的查询结果。有时太广的结果很难在屏幕上读出来。less的-S选项可以使结果更易于读,因为可以用左、右箭头水平滚动它。还可以在less中交互式使用-S,以关闭或打开水平浏览模式。详细信息请阅读手册中的less页:
· shell> man less· 可以指定很复杂的pager命令来处理查询输出:
· mysql> PAGER cat | tee /dr1/tmp/res.txt \· | tee /dr2/tmp/res2.txt | less -n -i -S在该例子中,该命令将查询结果发送到位于/dr1和/dr2上安装的两个不同的文件系统中的两个不同目录中的两个文件中,但仍然可以通过less将结果显示在屏幕上。
还可以结合使用tee和pager函数。启用一个tee文件并将pager设置为less,能够使用less 程序浏览结果,并且仍然可以同时将内容添加到一个文件中。结合pager命令使用的Unix tee和 mysql嵌入式tee命令的差别是即使没有可用的Unix tee,嵌入式tee仍然可以工作。嵌入式tee还可以记录在屏幕上输出的内容,而结合pager命令使用的Unix tee不能记录那么多的内容。并且,可以从MySQL中交互式打开或关闭tee文件日志。当你想要将部分查询记录到一个文件中时很有用,但其它不适合。
默认mysql>提示符可以重新配置。定义提示符的字符串可以包含下面的特殊序列:
选项
描述
\v
服务器版本
\d
当前的数据库
\h
服务器主机
\p
当前的TCP/IP端口或套接字文件
\u
你的用户名
\U
你的全user_name@host_name账户名
\\
‘\’反斜线字符
\n
新行字符
\t
Tab字符
\
空格(反斜线后面的空格)
\_
空格
\R
当前的时间,24-小时军用时间(0-23)
\r
当前的时间,标准12-小时(1-12)
\m
当前时间的分钟
\y
当前的年,两位
\Y
当前的年,四位
\D
当前的日期
\s
当前时间的秒
\w
当前周的天,3字符格式(Mon,Tue,...)
\P
am/pm
\o
当前的月,数字格式
\O
当前的月,3字符格式(Jan,Feb,...)
\c
随发出的每个语句递增的计数
\S
分号
\'
单引号
\"
双引号
‘\’后面跟随的其它字母则变为该字母。
如果不用任何参量指定提示命令,mysql将提示重新设置位默认mysql>。
可以用几种方式设置提示:
· 使用环境变量
可以用MYSQL_PS1环境变量来设置提示字符串。例如:
shell> export MYSQL_PS1="(\u@\h) [\d]> "· 使用选项文件
可以在MySQL选项文件中的[mysql]组设置提示,例如根目录中的/etc/my.cnf或.my.cnf文件。例如:
[mysql]prompt=(\\u@\\h) [\\d]>\\_在该例子中,请注意反斜线是双线。如果使用选项文件中的prompt选项来设置提示,当使用特殊提示选项时,建议使用双反斜线。在允许的提示选项和选项文件中可识别的特殊转义序列中有部分重叠。(这些序列列于4.3.2节,“使用选项文件”)。如果使用单反斜线,会遇到问题。例如,\s被解释为空格而不是当前的秒值。下面的例子显示了如何在选项文件中定义提示以包括当前的时间,格式为HH:MM:SS>:
[mysql]prompt="\\r:\\m:\\s> "· 使用命令行选项
可以在mysql的命令行中设置--prompt选项。例如:
shell> mysql --prompt="(\u@\h) [\d]> "(user@host) [database]>· 交互式
你可以使用prompt(或\R)命令交互地更改提示。例如:
mysql> prompt (\u@\h) [\d]>\_PROMPT set to '(\u@\h) [\d]>\_'(user@host) [database]>(user@host) [database]> promptReturning to default PROMPT of mysql>mysql>8.3.3. 怎样从文本文件执行SQL语句
mysql客户程序一般交互使用:
shell> mysql db_name还可以将SQL语句放到一个文件中然后告诉mysql从该文件读取输入。要想实现,创建一个文本文件text_file,并包含你想要执行的语句。然后按如下所示调用mysql:
shell> mysql db_name < text_file还可以用一个USE db_name语句启动文本文件。在这种情况下,不需要在命令行中指定数据库名:
shell> mysql < text_file如果正运行mysql,可以使用source或\.命令执行SQL脚本文件:
mysql> source filenamemysql> \. filename有时想要使用脚本来向用户显示进度信息;为此可以插入下述行:
SELECT '<info_to_display>' AS ' ';将输出<info_to_display>。
关于批处理模式的详细信息,参见3.5节,“在批处理模式下使用mysql”。
8.3.4. mysql技巧
8.3.4.1. 垂直显示查询结果
8.3.4.2. 使用--safe-updates选项
8.3.4.3. 禁用mysql自动连接
该节描述了可以帮助你更有效使用mysql的一些技术。
8.3.4.1. 垂直显示查询结果
一些查询结果如果垂直显示而不用通常的水平表格式显示,则更容易读取。用\G而不用分号结束查询可以垂直显示查询。例如,包括新行的更长的文本值垂直输出时通常更容易读取:
mysql> SELECT * FROM mails WHERE LENGTH(txt) < 300 LIMIT 300,1\G
*************************** 1. row ***************************
msg_nro: 3068
date: 2000-03-01 23:29:50
time_zone: +0200
mail_from: Monty
reply: monty@no.spam.com
mail_to: "Thimble Smith" <tim@no.spam.com>
sbj: UTF-8
txt: >>>>> "Thimble" == Thimble Smith writes:
Thimble> Hi. I think this is a good idea. Is anyone familiar
Thimble> with UTF-8 or Unicode? Otherwise, I'll put this on my
Thimble> TODO list and see what happens.
Yes, please do that.
Regards,
Monty
file: inbox-jani-1
hash: 190402944
1 row in set (0.09 sec)
8.3.4.2. 使用--safe-updates选项
对于新手,有一个有用的启动选项--safe-updates(或--i-am-a-dummy,具有相同的效果)。当你已经发出一个DELETE FROM tbl_name语句但忘记了WHERE子句时很有用。通常情况,这样的语句从表中删除所有行。用--safe-updates,可以通过指定可以识别它们的键值只删除某些行。这样可以帮助防止事故。
若使用--safe-updates选项,mysql连接MySQL服务器时发出下面的语句:
SET SQL_SAFE_UPDATES=1,SQL_SELECT_LIMIT=1000, SQL_MAX_JOIN_SIZE=1000000;参见13.5.3节,“SET语法”。
SET语句有下面的效果:
· 不允许你执行UPDATE或DELETE语句,除非在WHERE子句中指定一个键值约束或提供一个LIMIT子句(或二者皆使用)。例如:
· UPDATE tbl_name SET not_key_column=val WHERE key_column=val;· · UPDATE tbl_name SET not_key_column=val LIMIT 1;· 所有大的SELECT结果自动限制到1,000行,除非语句包括一个LIMIT子句。
· 放弃可能需要检查1,000,000多行组合的多表SELECT语句。
要将限制指定为1,000和1,000,000之外的值,可以使用--select_limit和--max_join_size选项覆盖默认值:
shell> mysql --safe-updates --select_limit=500 --max_join_size=100008.3.4.3. 禁用mysql自动连接
如果mysql客户程序发送查询时断开与服务器的连接,它立即并自动尝试重新连接服务器并再次发送查询。然而,即使mysql重新连接成功,你的第1个连接也已经结束,并且以前的会话对象和设定值被丢失:包括临时表、自动提交模式,以及用户和会话变量。该行为很危险,如下面的例子所示,服务器将在你不知道的情况下关闭并重启:
mysql> SET @a=1;Query OK, 0 rows affected (0.05 sec) mysql> INSERT INTO t VALUES(@a);ERROR 2006: MySQL server has gone awayNo connection. Trying to reconnect...Connection id: 1Current database: test Query OK, 1 row affected (1.30 sec) mysql> SELECT * FROM t;+------+| a |+------+| NULL |+------+1 row in set (0.05 sec)@a用户变量已经随连接丢失,并且重新连接后它也没有定义。如果有必要在连接断开时终止mysql并提示错误,你可以用--skip-reconnect选项启动mysql客户程序。
8.4. mysqlaccess:用于检查访问权限的客户端
mysqlaccess是Yves Carlier为MySQL分发提供的一个诊断工具。它检查访问权限的主机名、用户名和数据库组合。请注意 mysqlaccess检查只使用user、db和host表的访问。它不检查在tables_priv、columns_priv或procs_priv表中指定的表、列或者程序的权限。
调用mysqlaccess的方法:
shell> mysqlaccess [host_name [user_name [db_name]]] [options]mysqlaccess理解下面的选项:
· ---help,-?
显示帮助消息并退出。
· --brief,-b
生成单行表格式的报告。
· --commit
从临时表将新访问权限复制到原授权表。必须为新的权限刷新授权表以使其生效。(例如,执行mysqladmin RELOAD命令)。
· --copy
从原授权表重载临时授权表。
· --db=db_name,-d db_name
指定数据库名。
· ---debug=N
指定调试级别。N可以为从0到3的一个整数。
· --host=host_name,-h host_name
在访问权限中使用的主机名。
· --howto
显示一些例子显示如何使用mysqlaccess。
· --old_server
假定服务器是一个旧版本的MySQL服务器(MySQL 3.21之前),还不知道如何处理全WHERE子句。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果你在命令行中在--password或-p选项后面省略 密码值,将提示你输入密码。
· --plan
显示将来发布的建议和思想。
· --preview
更改临时授权表后显示权限的不同。
· --relnotes
显示发布注解。
· --rhost=host_name,-H host_name
连接给定主机的MySQL服务器。
· --rollback
取消对临时授权表的最新的更改。
· --spassword[=password],-P[password]
以super用户连接服务器时使用的密码。如果在命令行中在--password或-p选项后面省略了 密码值,将提示你输入密码。
· --superuser=user_name,-U user_name
指定以super用户连接时的用户名。
· --tables,-t
生成表格式的报告。
· --user=user_name,-u user_name
在访问权限中使用的主机名。
· --version,-v
显示版本信息并退出。
如果你的MySQL分发安装在某个非标准位置,必须进入mysqlaccess期望找到mysql客户的目录。编辑大约在18行处的mysqlaccess脚本。搜索类似下面的一行:
$MYSQL = '/usr/local/bin/mysql'; # path to mysql executable将路径更改为mysql实际在系统中保存的位置。如果不这样做,当运行mysqlaccess时会发生Broken pipe错误。
8.5. mysqladmin:用于管理MySQL服务器的客户端
mysqladmin是一个执行管理操作的客户程序。可以用它来检查服务器的配置和当前的状态,创建并删除数据库等等。
这样调用mysqladmin:
shell> mysqladmin [options] command [command-options] [command [command-options]] ...mysqladmin支持下面的命令:
· create db_name
创建一个名为db_name的新数据库。
· debug
告诉服务器向错误日志写入调试信息。
· drop db_name
删除名为db_nam的数据库和所有表。
· extended-status
显示服务器状态变量及其值。
· flush-hosts
刷新主机缓存中的所有信息。
· flush-logs
刷新所有日志。
· flush-privileges
重载授权表(类似reload)。
· flush-status
清除状态变量。
· flush-tables
刷新所有表。
· flush-threads
刷新线程缓存。
· kill id,id,...
杀掉服务器线程。
· old-password new-password
类似password但使用旧的(pre-4.1)密码哈希格式保存 密码。(参见5.7.9节,“MySQL 4.1中的密码哈希处理”)。
· password new-password
设置一个新密码。将用mysqladmin连接服务器使用的 账户的密码更改为new-password。
如果new-password包含空格或其它命令解释符的特殊字符,需要用引号将它引起来。在Windows中,一定要使用双引号而不要用单引号;单引号不会从 密码中剥离出来,而是解释为密码的一部分。例如:
shell> mysqladmin password "my new password"
· ping
检查服务器是否仍活动。如果服务器在运行mysqladmin返回状态0,如果不运行返回1。即使出现错误例如Access denied也为0,因为这说明服务器在运行但拒绝了连接,与服务器不在运行不同。
· processlist
显示活动服务器线程的列表。类似SHOW PROCESSLIST语句的输出。如果给出了--verbose选项,输出类似SHOW FULL PROCESSLIST。(参见13.5.4.16节,“SHOW PROCESSLIST语法”)。
· reload
重载授权表。
· refresh
刷新所有表并关闭和打开日志文件。
· shutdown
停止服务器。
· start-slave
开始从服务器上的复制。
· status
显示短服务器状态消息。
· stop-slave
停止从服务器上的复制。
· variables
显示服务器系统变量及其值。
· version
显示服务器的版本信息。
所有命令可以简化为任何唯一的前缀。例如:
shell> mysqladmin proc stat+----+-------+-----------+----+---------+------+-------+------------------+| Id | User | Host | db | Command | Time | State | Info |+----+-------+-----------+----+---------+------+-------+------------------+| 51 | monty | localhost | | Query | 0 | | show processlist |+----+-------+-----------+----+---------+------+-------+------------------+Uptime: 1473624 Threads: 1 Questions: 39487 Slow queries: 0 Opens: 541 Flush tables: 1 Open tables: 19 Queries per second avg: 0.0268 mysqladmin status命令的结果显示下面的值:
· Uptime
MySQL服务器已经运行的秒数。
· Threads
活动线程(客户)的数目。
· Questions
服务器启动以来客户的问题(查询)数目。
· Slow queries
执行时间超过long_query_time秒的查询的数量。参见5.11.4节,“慢速查询日志”。
· Opens
服务器已经打开的数据库表的数量。
· Flush tables
服务器已经执行的flush ...、refresh和reload命令的数量。
· Open tables
目前打开的表的数量。
· Memory in use
mysqld代码直接分配的内存数量。只有用--with--debug=full编译了MySQL该值才显示。
· Maximum memory used
mysqld代码直接分配的最大内存数量。只有用--with--debug=full编译了MySQL该值才显示。
如果当使用Unix套接字文件连接本地服务器时执行mysqladmin shutdown,mysqladmin将等待直到服务器的进程ID文件被删除,以确保服务器正确停止。
mysqladmin支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --character-sets-dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --compress,-C
压缩客户和服务器之间发送的所有信息(如果二者均支持压缩)。
· --count=num,-c num
迭代数目。该选项只有结合--sleep (-i)才能工作。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。 默认为'd:t:o,/tmp/mysqladmin.trace'。
· --default-character-set=charset
使用charsetas作为默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --force,-f
不再为drop database命令进行确认。对于多个命令,即使出现错误也继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --password[=password],-p[password]
连接服务器使用的密码。如果使用短选项形式(-p),该选项和 密码之间不能有空格。如果你在命令行中在--password或-p选项后面省略 密码值,将提示你输入密码。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --relative,-r
当带-I使用时显示当前和前面值的差别。目前,该选项只用于extended-status命令。
· --silent,-s
如果不能建立与服务器的连接则以沉默方式退出。
· --sleep=delay,-i delay
每睡眠delay秒后执行一次命令。
· --socket=path,-S path
用于连接的套接字文件。
· --user=user_name,-u user_name
当连接服务器时使用的MySQL用户名。
· --verbose,-v
冗长模式。打印出程序操作的详细信息。
· --version,-V
显示版本信息并退出。
· --vertical,-E
垂直打印输出。类似于--relative,但垂直打印输出。
· --wait[=count],-w[count]
如果连接不能建立,等待并重试而不是放弃。如果给出一个选项值,则指示重试的次数。默认是一次。
也可以使用--var_name=value选项设置下面的变量:
· connect_timeout
连接超时之前的最大秒数。默认值为43200(12小时)。
· shutdown_timeout
等候关闭的最大秒数。默认值为3600(1小时)。
也可以使用--set-variable=var_name=value或-O var_name=value语法来设置变量。然而,现在不赞成该语法,并且不再使用。
8.6. mysqlbinlog:用于处理二进制日志文件的实用工具
服务器生成的二进制日志文件写成二进制格式。要想检查这些文本格式的文件,应使用mysqlbinlog实用工具。
应这样调用mysqlbinlog:
shell> mysqlbinlog [options] log-files...例如,要想显示二进制日志binlog.000003的内容,使用下面的命令:
shell> mysqlbinlog binlog.0000003输出包括在binlog.000003中包含的所有语句,以及其它信息例如每个语句花费的时间、客户发出的线程ID、发出线程时的时间戳等等。
通常情况,可以使用mysqlbinlog直接读取二进制日志文件并将它们用于本地MySQL服务器。也可以使用--read-from-remote-server选项从远程服务器读取二进制日志。
当读取远程二进制日志时,可以通过连接参数选项来指示如何连接服务器,但它们经常被忽略掉,除非你还指定了--read-from-remote-server选项。这些选项是--host、--password、--port、--protocol、--socket和--user。
还可以使用mysqlbinlog来读取在复制过程中从服务器所写的中继日志文件。中继日志格式与二进制日志文件相同。
在5.11.3节,“二进制日志”中详细讨论了二进制日志。
mysqlbinlog支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· ---database=db_name,-d db_name
只列出该数据库的条目(只用本地日志)。
· --force-read,-f
使用该选项,如果mysqlbinlog读它不能识别的二进制日志事件,它会打印警告,忽略该事件并继续。没有该选项,如果mysqlbinlog读到此类事件则停止。
· --hexdump,-H
在注释中显示日志的十六进制转储。该输出可以帮助复制过程中的调试。在MySQL 5.1.2中添加了该选项。
· --host=host_name,-h host_name
获取给定主机上的MySQL服务器的二进制日志。
· --local-load=path,-l pat
为指定目录中的LOAD DATA INFILE预处理本地临时文件。
· --offset=N,-o N
跳过前N个条目。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。
· --port=port_num,-P port_num
用于连接远程服务器的TCP/IP端口号。
· --position=N,-j N
不赞成使用,应使用--start-position。
· --protocol={TCP | SOCKET | PIPE | -position
使用的连接协议。
· --read-from-remote-server,-R
从MySQL服务器读二进制日志。如果未给出该选项,任何连接参数选项将被忽略。这些选项是--host、--password、--port、--protocol、--socket和--user。
· --result-file=name, -r name
将输出指向给定的文件。
· --short-form,-s
只显示日志中包含的语句,不显示其它信息。
· --socket=path,-S path
用于连接的套接字文件。
· --start-datetime=datetime
从二进制日志中第1个日期时间等于或晚于datetime参量的事件开始读取。datetime值相对于运行mysqlbinlog的机器上的本地时区。该值格式应符合DATETIME或TIMESTAMP数据类型。例如:
shell> mysqlbinlog --start-datetime="2004-12-25 11:25:56" binlog.000003该选项可以帮助点对点恢复。
· --stop-datetime=datetime
从二进制日志中第1个日期时间等于或晚于datetime参量的事件起停止读。关于datetime值的描述参见--start-datetime选项。该选项可以帮助及时恢复。
· --start-position=N
从二进制日志中第1个位置等于N参量时的事件开始读。
· --stop-position=N
从二进制日志中第1个位置等于和大于N参量时的事件起停止读。
· --to-last-logs,-t
在MySQL服务器中请求的二进制日志的结尾处不停止,而是继续打印直到最后一个二进制日志的结尾。如果将输出发送给同一台MySQL服务器,会导致无限循环。该选项要求--read-from-remote-server。
· --disable-logs-bin,-D
禁用二进制日志。如果使用--to-last-logs选项将输出发送给同一台MySQL服务器,可以避免无限循环。该选项在崩溃恢复时也很有用,可以避免复制已经记录的语句。注释:该选项要求有SUPER权限。
· --user=user_name,-u user_name
连接远程服务器时使用的MySQL用户名。
· --version,-V
显示版本信息并退出。
还可以使用--var_name=value选项设置下面的变量:
· open_files_limit
指定要保留的打开的文件描述符的数量。
可以将mysqlbinlog的输出传到mysql客户端以执行包含在二进制日志中的语句。如果你有一个旧的备份,该选项在崩溃恢复时也很有用(参见5.9.1节,“数据库备份”):
shell> mysqlbinlog hostname-bin.000001 | mysql或:
shell> mysqlbinlog hostname-bin.[0-9]* | mysql如果你需要先修改含语句的日志,还可以将mysqlbinlog的输出重新指向一个文本文件。(例如,想删除由于某种原因而不想执行的语句)。编辑好文件后,将它输入到mysql程序并执行它包含的语句。
mysqlbinlog有一个--position选项,只打印那些在二进制日志中的偏移量大于或等于某个给定位置的语句(给出的位置必须匹配一个事件的开始)。它还有在看见给定日期和时间的事件后停止或启动的选项。这样可以使用--stop-datetime选项进行点对点恢复(例如,能够说“将数据库前滚动到今天10:30 AM的位置”)。
如果MySQL服务器上有多个要执行的二进制日志,安全的方法是在一个连接中处理它们。下面是一个说明什么是不安全的例子:
shell> mysqlbinlog hostname-bin.000001 | mysql # DANGER!!shell> mysqlbinlog hostname-bin.000002 | mysql # DANGER!!使用与服务器的不同连接来处理二进制日志时,如果第1个日志文件包含一个CREATE TEMPORARY TABLE语句,第2个日志包含一个使用该临时表的语句,则会造成问题。当第1个mysql进程结束时,服务器撤销临时表。当第2个mysql进程想使用该表时,服务器报告 “不知道该表”。
要想避免此类问题,使用一个连接来执行想要处理的所有二进制日志中的内容。下面提供了一种方法:
shell> mysqlbinlog hostname-bin.000001 hostname-bin.000002 | mysql另一个方法是:
shell> mysqlbinlog hostname-bin.000001 > /tmp/statements.sqlshell> mysqlbinlog hostname-bin.000002 >> /tmp/statements.sqlshell> mysql -e "source /tmp/statements.sql"mysqlbinlog产生的输出可以不需要原数据文件即可重新生成一个LOAD DATA INFILE操作。mysqlbinlog将数据复制到一个临时文件并写一个引用该文件的LOAD DATA LOCAL INFILE语句。由系统确定写入这些文件的目录的默认位置。要想显式指定一个目录,使用--local-load选项。
因为mysqlbinlog可以将LOAD DATA INFILE语句转换为LOAD DATA LOCAL INFILE语句(也就是说,它添加了LOCAL),用于处理语句的客户端和服务器必须配置为允许LOCAL操作。参见5.6.4节,“LOAD DATA LOCAL安全问题”。
警告:为LOAD DATA LOCAL语句创建的临时文件不会自动删除,因为在实际执行完那些语句前需要它们。不再需要语句日志后应自己删除临时文件。文件位于临时文件目录中,文件名类似original_file_name-#-#。
--hexdump选项可以在注释中产生日志内容的十六进制转储:
shell> mysqlbinlog --hexdump master-bin.000001上述命令的输出应类似:
/*!40019 SET @@session.max_insert_delayed_threads=0*/;/*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/;# at 4#051024 17:24:13 server id 1 end_log_pos 98# Position Timestamp Type Master ID Size Master Pos Flags# 00000004 9d fc 5c 43 0f 01 00 00 00 5e 00 00 00 62 00 00 00 00 00# 00000017 04 00 35 2e 30 2e 31 35 2d 64 65 62 75 67 2d 6c |..5.0.15.debug.l|# 00000027 6f 67 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |og..............|# 00000037 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 |................|# 00000047 00 00 00 00 9d fc 5c 43 13 38 0d 00 08 00 12 00 |.......C.8......|# 00000057 04 04 04 04 12 00 00 4b 00 04 1a |.......K...|# Start: binlog v 4, server v 5.0.15-debug-log created 051024 17:24:13# at startupROLLBACK;十六进制转储的输出包含下面的元素:
· Position: The byte position within the log file.
· Timestamp: The event timestamp. In the example just shown, '9d fc 5c 43' is the representation of '051024 17:24:13' in hexadecimal.
· Type: The type of the log event. '0f' means that the example event is a FORMAT_DESCRIPTION_EVENT. The types are:
· 00 UNKNOWN_EVENT· This event should never be present in the log.· 01 START_EVENT_V3· This indicates the start of a log file written by MySQL 4 or earlier.· 02 QUERY_EVENT· The most common type of events. These contain queries executed· on the master.· 03 STOP_EVENT· Indicates that master has stopped.· 04 ROTATE_EVENT· Written when the master switches to a new log file.· 05 INTVAR_EVENT· Used mainly for AUTO_INCREMENT values and if the LAST_INSERT_ID()· function is used in the statement.· 06 LOAD_EVENT· Used for LOAD DATA INFILE in MySQL 3.23.· 07 SLAVE_EVENT· Reserved for future use.· 08 CREATE_FILE_EVENT· Used for LOAD DATA INFILE statements. This indicates the start· of execution of such a statement. A temporary file is created· on the slave. Used in MySQL 4 only.· 09 APPEND_BLOCK_EVENT· Contains data for use in a LOAD DATA INFILE statement. The· data is stored in the temporary file on the slave.· 0a EXEC_LOAD_EVENT· Used for LOAD DATA INFILE statements. The contents of the· temporary file is stored in the table on the slave.· Used in MySQL 4 only.· 0b DELETE_FILE_EVENT· Rollback of LOAD DATA INFILE statement. The temporary file· should be deleted on slave.· 0c NEW_LOAD_EVENT· Used for LOAD DATA INFILE in MySQL 4 and earlier.· 0d RAND_EVENT· Used to send information about random values if the RAND()· function is used in the query.· 0e USER_VAR_EVENT· Used to replicate user variables.· 0f FORMAT_DESCRIPTION_EVENT· This indicates the start of a log file written by MySQL 5 or later.· 10 XID_EVENT· Event indicating commit of XA transaction· 11 BEGIN_LOAD_QUERY_EVENT· Used for LOAD DATA statements in MySQL 5 and later.· 12 EXECUTE_LOAD_QUERY_EVENT· Used for LOAD DATA statements in MySQL 5 and later.· 13 TABLE_MAP_EVENT· Reserved for future use· 14 WRITE_ROWS_EVENT· Reserved for future use· 15 UPDATE_ROWS_EVENT· Reserved for future use· 16 DELETE_ROWS_EVENT· Reserved for future use· Master ID: The server id of the master that created the event.
· Size: The size in bytes of the event.
· Master Pos: The position of the event in the original master log file.
· Flags: 16 flags.
· 01 LOG_EVENT_BINLOG_IN_USE_F· Log file correctly closed (Used only in FORMAT_DESCRIPTION_EVENT)· If this flag is set (if the flags are e.g. '01 00') in an· FORMAT_DESCRIPTION_EVENT, then the log file has not been· properly closed. Most probably because of a master crash (for· example, due to power failure).· 02 Reserved for future use.· 04 LOG_EVENT_THREAD_SPECIFIC_F· Set if the event is dependent on the connection it was· executed in (example '04 00'), e.g. if the event uses· temporary tables.· 08 LOG_EVENT_SUPPRESS_USE_F· Set in some circumstances when the event is not dependent on· the current database其它标志保留用于将来使用。
在以后的版本中十六进制转储输出的格式可能会改变。
8.7. mysqlcheck:表维护和维修程序
mysqlcheck客户端可以检查和修复MyISAM表。它还可以优化和分析表。
mysqlcheck的功能类似myisamchk,但其工作不同。主要差别是当mysqld服务器在运行时必须使用mysqlcheck,而myisamchk应用于服务器没有运行时。使用mysqlcheck的好处是不需要停止服务器来检查或修复表。
Mysqlcheck为用户提供了一种方便的使用SQL语句CHECK TABLE、REPAIR TABLE、ANALYZE TABLE和OPTIMIZE TABLE的方式。它确定在要执行的操作中使用使用哪个语句,然后将语句发送到要执行的服务器上。
有3种方式来调用mysqlcheck:
shell> mysqlcheck[options] db_name [tables]shell> mysqlcheck[options] ---database DB1 [DB2 DB3...]shell> mysqlcheck[options] --all--database如果没有指定任何表或使用---database或--all--database选项,则检查整个数据库。
同其它客户端比较,mysqlcheck有一个特殊特性。重新命名二进制可以更改检查表的默认行为(--check)。如果你想要一个工具默认可以修复表的工具,只需要将mysqlcheck重新复制为mysqlrepair,或者使用一个符号链接mysqlrepair链接mysqlcheck。如果调用mysqlrepair,可按照命令修复表。
下面的名可用来更改mysqlcheck的默认行为:
mysqlrepair
默认选项为--repair
mysqlanalyze
默认选项为--analyze
mysqloptimize
默认选项为--optimize
mysqlcheck支持下面的选项:
· ---help,-?
显示帮助消息并退出。
· --all--database,-A
检查所有数据库中的所有表。与使用---database选项相同,在命令行中命名所有数据库。
· --all-in-1,-1
不是为每个表发出一个语句,而是为命名数据库中待处理的所有表的每个数据库执行一个语句。
· --analyze,-a
分析表。
· --auto-repair
如果某个被检查的表破坏了,自动修复它。检查完所有表后自动进行所有需要的修复。
· --character-sets-dir=path
字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。
· --check,-c
检查表的错误。
· --check-only-changed,-C
只检查上次检查以来已经更改的或没有正确关闭的表。
· --compress
压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。
· ---database,-B
处理数据库中命名的所有表。使用该选项,所有字名参量被看作数据库名,而不是表名。
· ---debug[=debug_options],-# [debug_options]
写调试日志。debug_options字符串通常为'd:t:o,file_name'。
· --default-character-set=charset
使用charsetas默认字符集。参见5.10.1节,“数据和排序用字符集”。
· --extended,-e
如果你正使用该选项来检查表,可以确保它们100%地一致,但需要很长的时间。
如果你正使用该选项来修复表,则运行扩展修复,不但执行的时间很长,而且还会产生大量的垃圾行!
· --fast,-F
只检查没有正确关闭的表。
· --force,-f
即使出现SQL错误也继续。
· --host=host_name,-h host_name
连接给定主机上的MySQL服务器。
· --medium-check,-m
执行比--extended操作更快的检查。只能发现99.99%的错误,在大多数情况下这已经足够了。
· --optimize,-o
优化表。
· --password[=password],-p[password]
当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password或-p选项后面没有 密码值,则提示输入一个密码。
· --port=port_num,-P port_num
用于连接的TCP/IP端口号。
· --protocol={TCP | SOCKET | PIPE | MEMORY}
使用的连接协议。
· --quick,-q
如果你正使用该选项在检查表,它防止扫描行以检查错误链接的检查。这是最快的检查方法。
如果你正使用该选项在修复表,它尝试只修复索引树。这是最快的修复方法。
· --repair,-r
执行可以修复大部分问题的修复,只是唯一值不唯一时不能修复。
· --silent,-s
沉默模式。只打印错误消息。
· --socket=path,-S path
用于连接的套接字文件。
· --tables
覆盖---database或-B选项。选项后面的所有参量被视为表名。
· --user=user_name,-u user_name
当连接服务器时使用的MySQL用户名。
· --verbose
发表评论
-
解决Rails2.33 与Mysql连接问题
2009-08-20 11:36 1126rails2.3.3 连接数据库问题, 首先升级数据库gem ... -
Restful Authentication插件
2009-07-21 10:27 1007Restful Authentication插件为你生成一个R ... -
升级gem
2009-06-30 16:57 905ROR的时候看到这样的提示: Rails requires R ... -
Ruby Gui 图形开发的工具
2009-01-07 14:49 1561ActiveTcl 到:http://downloads.ac ... -
Ruby on Rails有用的插件(转)
2008-01-24 15:14 1254Ruby on Rails有用的插件(转) 文件上传(File ... -
Active Record 初解
2008-01-22 17:30 10401.关联 n:1: belongs_to: XXXX 1:n: ... -
rails 命令用法
2008-01-21 14:03 17561.1 创建一个Rails应用程序 $ rails a ... -
MySQL参考手册
2008-01-10 13:11 1178[url=http://dev.mysql.com/doc/r ... -
Mysql命令操作
2008-01-10 13:04 967一、连接MYSQL。 格式 ... -
MySQL实用命令
2008-01-10 13:00 982MySQL实用命令 Wikipedia,自由的百科全书 一) ... -
学习MySQL常用操作命令
2008-01-10 12:45 8801、启动MySQL服务器 实际上上篇已讲到如何启动MySQ ...
相关推荐
MySQL客户端是用于与MySQL服务器通信的应用程序,尤其在Linux环境下,它是开发人员和系统管理员进行数据库管理和维护不可或缺的工具。本文将深入探讨“mysql_client for Linux”中的最新MySQL客户端,包括其功能、...
7. **其他工具**:除了`mysql`命令行工具外,可能还有`mysqladmin`(执行服务器管理任务),`mysqlcheck`(检查和修复表),`mysqlshow`(显示数据库、表和字段信息)等实用程序。 在Linux环境中,理解并熟练使用...
在本篇文章中,我们将深入探讨MySQL-Front作为MySQL客户端的使用和功能。 1. **安装与启动**: - MySQL-Front的安装通常是一个简单的过程,只需运行`MySQL-Front_Setup.exe`文件,按照向导的指示完成安装。安装...
总的来说,MyManager作为一款优秀的MySQL客户端工具,不仅提供了丰富的数据库管理功能,还以其易用性和高效性赢得了用户的青睐。无论是新手还是经验丰富的DBA,都能从中受益,提升数据库管理工作效率。
而“非常好用的mysql客户端”通常指的是能够方便地管理和操作MySQL数据库的应用程序。在这个场景下,提到的“Navicat Premium”就是这样一个强大的数据库管理工具。 Navicat Premium是一款综合性的数据库管理软件,...
接下来是`MySQL-client-5.6.26-1.linux_glibc2.5.x86_64.rpm`,这是MySQL客户端的安装包,包含了连接MySQL服务器所需的命令行工具,如`mysql`, `mysqladmin`, `mysqldump`等。`mysql`命令行客户端用于交互式地查询...
在开发环境中,MySQL客户端是不可或缺的工具,它能够帮助开发者调试应用程序的数据库部分,进行数据迁移,备份和恢复数据库,以及进行性能调优。对于大型企业,MySQL客户端也可能与其他数据库管理工具(如phpMyAdmin...
它包括 `mysql` 命令行客户端、`mysqladmin` 管理工具和其他相关实用程序,是数据库管理员和开发人员日常工作中不可或缺的一部分。 2. **CentOS 7**: CentOS 是一个基于 Red Hat Enterprise Linux 的开源操作系统,...
总之,Navicat作为一款强大的可视化MySQL客户端工具,集成了数据库连接、数据管理、设计、同步等多种功能,是数据库管理员和开发者的得力助手。通过熟练使用Navicat,可以显著提高数据库管理工作效率,降低出错概率...
在本文中,我们将深入探讨三种常用的MySQL客户端工具:MySQL Command Line Client、MySQL Query Browser以及SQL Manager for MySQL。 1. **MySQL Command Line Client** MySQL自带的命令行工具是所有MySQL安装的...
标题 "连接SQL Server、Oracle、MySQL的客户端工具" 指出这是一款支持多数据库系统的通用客户端工具,允许用户方便地与SQL Server、Oracle和MySQL等数据库进行交互。这样的工具通常提供图形用户界面(GUI),使得...
**MySQL常用工具SQLyog小海豚** MySQL是一款广泛使用的开源关系型数据库管理系统,而SQLyog是针对MySQL设计的一款图形化管理工具,被誉为“小海豚”。它以其直观的界面、强大的功能和高效的性能,使得数据库管理和...
综上所述,这个"Golang编写的MySQL客户端工具"的源代码涵盖了许多重要的编程和数据库管理概念,包括Go语言的特性、MySQL的交互、并发处理、错误处理、命令行设计以及测试和配置管理。通过研究这些代码,开发者可以...
在本案例中提到的"很实用的mysql客户端"是一款专为MySQL设计的图形用户界面(GUI)工具,允许用户通过直观的方式进行数据库管理和维护。 这个客户端提供了以下关键功能: 1. **数据库管理**:用户可以通过该工具...
总结起来,"mysql数据库及客户端"的安装涉及MySQL服务器和GUI工具的安装,而提供的文档则对整个过程进行了详细的记录,对于初学者或需要升级MySQL环境的用户来说,这些都是宝贵的资源。通过理解并遵循这些步骤,可以...
与EMS(SQL Manager Suite for MySQL)等其他客户端工具相比,许多用户认为Navicat更易于使用,功能更加丰富和实用。 总的来说,Navicat Trial MySQL是MySQL管理员和开发人员的理想选择,无论你是初学者还是经验...
MySQL 命令行工具是使用最多的实用程序之一,对于快速测试和执行脚本非常有价值。本节将详细介绍 MySQL 命令行工具的使用和功能。 1. MySQL 命令行客户端: mysql mysql 命令行客户端是 MySQL 官方提供的命令行...
MySQL连接工具是数据库管理员和开发人员用来与MySQL服务器交互的重要应用程序。绿色版通常指的是免安装、便携式的版本,可以直接运行而无需在计算机上进行正式的安装过程,这对于需要在不同设备间移动工作或者不想...
MySQL客户端工具是数据库...总的来说,MySQL_Front作为一款免费的MySQL客户端工具,它的易用性和功能多样性使其成为管理和维护MySQL数据库的理想选择。无论你是新手还是经验丰富的开发者,都能从中受益,提高工作效率。