directory search
目录 前言 1. 一般信息 1.1. 关于本手册 1.2. 本手册采用的惯例 1.3. MySQL AB概述 1.4. MySQL数据库管理系统概述 1.4.1. MySQL的历史 1.4.2. MySQL的的主要特性 1.4.3. MySQL稳定性 1.4.4. MySQL表最大能达到多少 1.4.5. 2000年兼容性 1.5. MaxDB数据库管理系统概述 1.5.1. 什么是MaxDB? 1.5.2. MaxDB的历史 1.5.3. MaxDB的特性 1.5.4. 许可和支持 1.5.5. MaxDB和MySQL之间的特性差异 1.5.6. MaxDB和MySQL之间的协同性 1.5.7. 与MaxDB有关的链接 1.6. MySQL发展大事记 1.6.1. MySQL 5.1的新特性 1.7. MySQL信息源 1.7.1. MySQL邮件列表 1.7.2. IRC(在线聊天系统)上的MySQL社区支持 1.7.3. MySQL论坛上的MySQL社区支持 1.8. MySQL标准的兼容性 1.8.1. MySQL遵从的标准是什么 1.8.2. 选择SQL模式 1.8.3. 在ANSI模式下运行MySQL 1.8.4. MySQL对标准SQL的扩展 1.8.5. MySQL与标准SQL的差别 1.8.6. MySQL处理约束的方式 2. 安装MySQL 2.1. 一般安装问题 2.1.1. MySQL支持的操作系统 2.1.2. 选择要安装的MySQL分发版 2.1.3. 怎样获得MySQL 2.1.4. 通过MD5校验和或GnuPG验证软件包的完整性 2.1.5. 安装布局 2.2. 使用二进制分发版的标准MySQL安装 2.3. 在Windows上安装MySQL 2.3.1. Windows系统要求 2.3.2. 选择安装软件包 2.3.3. 用自动安装器安装MySQL 2.3.4. 使用MySQL安装向导 2.3.5. 使用配置向导 2.3.6. 通过非安装Zip文件安装MySQL 2.3.7. 提取安装档案文件 2.3.8. 创建选项文件 2.3.9. 选择MySQL服务器类型 2.3.10. 首次启动服务器 2.3.11. 从Windows命令行启动MySQL 2.3.12. 以Windows服务方式启动MySQL 2.3.13. 测试MySQL安装 2.3.14. 在Windows环境下对MySQL安装的故障诊断与排除 2.3.15. 在Windows下升级MySQL 2.3.16. Windows版MySQL同Unix版MySQL对比 2.4. 在Linux下安装MySQL 2.5.在Mac OS X中安装MySQL 2.6. 在NetWare中安装MySQL 2.7. 在其它类Unix系统中安装MySQL 2.8. 使用源码分发版安装MySQL 2.8.1. 源码安装概述 2.8.2. 典型配置选项 2.8.3. 从开发源码树安装 2.8.4. 处理MySQL编译问题 2.8.5. MIT-pthreads注意事项 2.8.6. 在Windows下从源码安装MySQL 2.8.7. 在Windows下编译MySQL客户端 2.9. 安装后的设置和测试 2.9.1. Windows下安装后的过程 2.9.2. Unix下安装后的过程 2.9.3. 使初始MySQL账户安全 2.10. 升级MySQL 2.10.1. 从5.0版升级 2.10.2. 升级授权表 2.10.3. 将MySQL数据库拷贝到另一台机器 2.11. 降级MySQL 2.12. 具体操作系统相关的注意事项 2.12.1. Linux注意事项 2.12.2. Mac OS X注意事项 2.12.3. Solaris注意事项 2.12.4. BSD注意事项 2.12.5. 其它Unix注意事项 2.12.6. OS/2注意事项 2.13. Perl安装注意事项 2.13.1. 在Unix中安装Perl 2.13.2. 在Windows下安装ActiveState Perl 2.13.3. 使用Perl DBI/DBD接口的问题 3. 教程 3.1. 连接与断开服务器 3.2. 输入查询 3.3. 创建并使用数据库 3.3.1. 创建并选择数据库 3.3.2. 创建表 3.3.3. 将数据装入表中 3.3.4. 从表检索信息 3.4. 获得数据库和表的信息 NoName 3.6. 常用查询的例子 3.6.1. 列的最大值 3.6.2. 拥有某个列的最大值的行 3.6.3. 列的最大值:按组 3.6.4. 拥有某个字段的组间最大值的行 3.6.5. 使用用户变量 3.6.6. 使用外键 3.6.7. 根据两个键搜索 3.6.8. 根据天计算访问量 3.6.9. 使用AUTO_INCREMENT 3.7. 孪生项目的查询 3.7.1. 查找所有未分发的孪生项 3.7.2. 显示孪生对状态的表 3.8. 与Apache一起使用MySQL 4. MySQL程序概述 4.1. MySQL程序概述 4.2. 调用MySQL程序 4.3. 指定程序选项 4.3.1. 在命令行上使用选项 4.3.2. 使用选项文件 4.3.3. 用环境变量指定选项 4.3.4. 使用选项设置程序变量 5. 数据库管理 5.1. MySQL服务器和服务器启动脚本 5.1.1. 服务器端脚本和实用工具概述 5.1.2. mysqld-max扩展MySQL服务器 5.1.3. mysqld_safe:MySQL服务器启动脚本 5.1.4. mysql.server:MySQL服务器启动脚本 5.1.5. mysqld_multi:管理多个MySQL服务器的程序 5.2. mysqlmanager:MySQL实例管理器 5.2.1. 用MySQL实例管理器启动MySQL服务器 5.2.2. 连接到MySQL实例管理器并创建用户账户 5.2.3. MySQL实例管理器命令行选项 5.2.4. MySQL实例管理器配置文件 5.2.5. MySQL实例管理器识别的命令 5.3. mysqld:MySQL服务器 5.3.1. mysqld命令行选项 5.3.2. SQL服务器模式 5.3.3. 服务器系统变量 5.3.4. 服务器状态变量 5.4. mysql_fix_privilege_tables:升级MySQL系统表 5.5. MySQL服务器关机进程 5.6. 一般安全问题 5.6.1. 通用安全指南 5.6.2. 使MySQL在攻击者面前保持安全 5.6.3. Mysqld安全相关启动选项 5.6.4. LOAD DATA LOCAL安全问题 5.7. MySQL访问权限系统 5.7.1. 权限系统的作用 5.7.2. 权限系统工作原理 5.7.3. MySQL提供的权限 5.7.4. 与MySQL服务器连接 5.7.5. 访问控制 5.7.6. 访问控制 5.7.7. 权限更改何时生效 5.7.8. 拒绝访问错误的原因 5.7.9. MySQL 4.1中的密码哈希处理 5.8. MySQL用户账户管理 5.8.1. MySQL用户名和密码 5.8.2. 向MySQL增加新用户账户 5.8.3. 从MySQL删除用户账户 5.8.4. 限制账户资源 5.8.5. 设置账户密码 5.8.6. 使你的密码安全 5.8.7. 使用安全连接 5.9. 备份与恢复 5.9.1. 数据库备份 5.9.2. 示例用备份与恢复策略 5.9.3. 自动恢复 5.9.4. 表维护和崩溃恢复 5.9.5. myisamchk:MyISAM表维护实用工具 5.9.6. 建立表维护计划 5.9.7. 获取关于表的信息 5.10. MySQL本地化和国际应用 5.10.1. 数据和排序用字符集 5.10.2. 设置错误消息语言 5.10.3. 添加新的字符集 5.10.4. 字符定义数组 5.10.5. 字符串比较支持 5.10.6. 多字节字符支持 5.10.7. 字符集问题 5.10.8. MySQL服务器时区支持 5.11. MySQL日志文件 5.11.1. 错误日志 5.11.2. 通用查询日志 5.11.3. 二进制日志 5.11.4. 慢速查询日志 5.11.5. 日志文件维护 5.12. 在同一台机器上运行多个MySQL服务器 5.12.1. 在Windows下运行多个服务器 5.12.2. 在Unix中运行多个服务器 5.12.3. 在多服务器环境中使用客户端程序 5.13. MySQL查询高速缓冲 5.13.1. 查询高速缓冲如何工作 5.13.2. 查询高速缓冲SELECT选项 5.13.3. 查询高速缓冲配置 5.13.4. 查询高速缓冲状态和维护 6. MySQL中的复制 6.1. 复制介绍 6.2. 复制实施概述 6.3. 复制实施细节 6.3.1. 复制主线程状态 6.3.2. 复制从I/O线程状态 6.3.3. 复制从SQL线程状态 6.3.4. 复制传递和状态文件 6.4. 如何设置复制 6.5. 不同MySQL版本之间的复制兼容性 6.6. 升级复制设置 6.6.1. 将复制升级到5.0版 6.7. 复制特性和已知问题 6.8. 复制启动选项 6.9. 复制FAQ 6.10. 复制故障诊断与排除 6.11. 通报复制缺陷 6.12. 多服务器复制中的Auto-Increment 7. 优化 7.1. 优化概述 7.1.1. MySQL设计局限与折衷 7.1.2. 为可移植性设计应用程序 7.1.3. 我们已将MySQL用在何处? 7.1.4. MySQL基准套件 7.1.5. 使用自己的基准 7.2. 优化SELECT语句和其它查询 7.2.1. EXPLAIN语法(获取SELECT相关信息) 7.2.2. 估计查询性能 7.2.3. SELECT查询的速度 7.2.4. MySQL怎样优化WHERE子句 7.2.5. 范围优化 7.2.6. 索引合并优化 7.2.7. MySQL如何优化IS NULL 7.2.8. MySQL如何优化DISTINCT 7.2.9. MySQL如何优化LEFT JOIN和RIGHT JOIN 7.2.10. MySQL如何优化嵌套Join 7.2.11. MySQL如何简化外部联合 7.2.12. MySQL如何优化ORDER BY 7.2.13. MySQL如何优化GROUP BY 7.2.14. MySQL如何优化LIMIT 7.2.15. 如何避免表扫描 7.2.16. INSERT语句的速度 7.2.17. UPDATE语句的速度 7.2.18. DELETE语句的速度 7.2.19. 其它优化技巧 7.3. 锁定事宜 7.3.1. 锁定方法 7.3.2. 表锁定事宜 7.4. 优化数据库结构 7.4.1. 设计选择 7.4.2. 使你的数据尽可能小 7.4.3. 列索引 7.4.4. 多列索引 7.4.5. MySQL如何使用索引 7.4.6. MyISAM键高速缓冲 7.4.7. MyISAM索引统计集合 7.4.8. MySQL如何计算打开的表 7.4.9. MySQL如何打开和关闭表 7.4.10. 在同一个数据库中创建多个表的缺陷 7.5. 优化MySQL服务器 7.5.1. 系统因素和启动参数的调节 7.5.2. 调节服务器参数 7.5.3. 控制查询优化器的性能 7.5.4. 编译和链接怎样影响MySQL的速度 7.5.5. MySQL如何使用内存 7.5.6. MySQL如何使用DNS 7.6. 磁盘事宜 7.6.1. 使用符号链接 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:杀死符合某一模式的进程 9. 语言结构 9.1. 文字值 9.1.1. 字符串 9.1.2. 数值 9.1.3. 十六进制值 9.1.4. 布尔值 9.1.5. 位字段值 9.1.6. NULL值 9.2. 数据库、表、索引、列和别名 9.2.1. 识别符限制条件 9.2.2. 识别符大小写敏感性 9.3. 用户变量 9.4. 系统变量 9.4.1. 结构式系统变量 9.5. 注释语法 9.6. MySQL中保留字的处理 10. 字符集支持 10.1. 常规字符集和校对 10.2. MySQL中的字符集和校对 10.3. 确定默认字符集和校对 10.3.1. 服务器字符集和校对 10.3.2. 数据库字符集和校对 10.3.3. 表字符集和校对 10.3.4. 列字符集和校对 10.3.5. 字符集和校对分配示例 10.3.6. 连接字符集和校对 10.3.7. 字符串文字字符集和校对 10.3.8. 在SQL语句中使用COLLATE 10.3.9. COLLATE子句优先 10.3.10. BINARY操作符 10.3.11. 校对确定较为复杂的一些特殊情况 10.3.12. 校对必须适合字符集 10.3.13. 校对效果的示例 10.4. 字符集支持影响到的操作 10.4.1. 结果字符串 10.4.2. CONVERT() 10.4.3. CAST() 10.4.4. SHOW语句 10.5. Unicode支持 10.6. 用于元数据的UTF8 10.7. 与其它DBMS的兼容性 10.8. 新字符集配置文件格式 10.9. 国家特有字符集 10.10. MySQL支持的字符集和校对 10.10.1. Unicode字符集 10.10.2. 西欧字符集 10.10.3. 中欧字符集 10.10.4. 南欧与中东字符集 10.10.5. 波罗的海字符集 10.10.6. 西里尔字符集 10.10.7. 亚洲字符集 11. 列类型 11.1. 列类型概述 11.1.1. 数值类型概述 11.1.2. 日期和时间类型概述 11.1.3. 字符串类型概述 11.2. 数值类型 11.3. 日期和时间类型 11.3.1. DATETIME、DATE和TIMESTAMP类型 11.3.2. TIME类型 11.3.3. YEAR类型 11.3.4. Y2K事宜和日期类型 11.4. String类型 11.4.1. CHAR和VARCHAR类型 11.4.2. BINARY和VARBINARY类型 11.4.3. BLOB和TEXT类型 11.4.4. ENUM类型 11.4.5. SET类型 11.5. 列类型存储需求 11.6. 选择正确的列类型 11.7. 使用来自其他数据库引擎的列类型 12. 函数和操作符 12.1. 操作符 12.1.1. 操作符优先级 12.1.2. 圆括号 12.1.3. 比较函数和操作符 12.1.4. 逻辑操作符 12.2. 控制流程函数 12.3. 字符串函数 12.3.1. 字符串比较函数 12.4. 数值函数 12.4.1. 算术操作符 12.4.2. 数学函数 12.5. 日期和时间函数 12.6. MySQL使用什么日历? 12.7. 全文搜索功能 12.7.1. 布尔全文搜索 12.7.2. 全文搜索带查询扩展 12.7.3. 全文停止字 12.7.4. 全文限定条件 12.7.5. 微调MySQL全文搜索 12.8. Cast函数和操作符 12.9. 其他函数 12.9.1. 位函数 12.9.2. 加密函数 12.9.3. 信息函数 12.9.4. 其他函数 NoName 12.10.1. GROUP BY(聚合)函数 12.10.2. GROUP BY修改程序 12.10.3. 具有隐含字段的GROUP BY 13. SQL语句语法 13.1. 数据定义语句 13.1.1. ALTER DATABASE语法 13.1.2. ALTER TABLE语法 13.1.3. CREATE DATABASE语法 13.1.4. CREATE INDEX语法 13.1.5. CREATE TABLE语法 13.1.6. DROP DATABASE语法 13.1.7. DROP INDEX语法 13.1.8. DROP TABLE语法 13.1.9. RENAME TABLE语法 13.2. 数据操作语句 13.2.1. DELETE语法 13.2.2. DO语法 13.2.3. HANDLER语法 13.2.4. INSERT语法 13.2.5. LOAD DATA INFILE语法 13.2.6. REPLACE语法 13.2.7. SELECT语法 13.2.8. Subquery语法 13.2.9. TRUNCATE语法 13.2.10. UPDATE语法 13.3. MySQL实用工具语句 13.3.1. DESCRIBE语法(获取有关列的信息) 13.3.2. USE语法 13.4. MySQL事务处理和锁定语句 13.4.1. START TRANSACTION 13.4.2. 不能回滚的语句 13.4.3. 会造成隐式提交的语句 13.4.4. SAVEPOINT和ROLLBACK TO SAVEPOINT语法 13.4.5. LOCK TABLES和UNLOCK TABLES语法 13.4.6. SET TRANSACTION语法 13.4.7. XA事务 13.5. 数据库管理语句 13.5.1. 账户管理语句 13.5.2. 表维护语句 13.5.3. SET语法 13.5.4. SHOW语法 13.5.5. 其它管理语句 13.6. 复制语句 13.6.1. 用于控制主服务器的SQL语句 13.6.2. 用于控制从服务器的SQL语句 13.7. 用于预处理语句的SQL语法 14. 插件式存储引擎体系结构 14.1. 前言 14.2. 概述 14.3. 公共MySQL数据库服务器层 14.4. 选择存储引擎 14.5. 将存储引擎指定给表 14.6. 存储引擎和事务 14.7. 插入存储引擎 14.8. 拔出存储引擎 14.9. 插件式存储器的安全含义 15. 存储引擎和表类型 15.1. MyISAM存储引擎 15.1.1. MyISAM启动选项 15.1.2. 键所需的空间 15.1.3. MyISAM表的存储格式 15.1.4. MyISAM表方面的问题 15.2. InnoDB存储引擎 15.2.1. InnoDB概述 15.2.2. InnoDB联系信息 15.2.3. InnoDB配置 15.2.4. InnoDB启动选项 15.2.5. 创建InnoDB表空间 15.2.6. 创建InnoDB表 15.2.7. 添加和删除InnoDB数据和日志文件 15.2.8. InnoDB数据库的备份和恢复 15.2.9. 将InnoDB数据库移到另一台机器上 15.2.10. InnoDB事务模型和锁定 15.2.11. InnoDB性能调节提示 15.2.12. 多版本的实施 15.2.13. 表和索引结构 15.2.14. 文件空间管理和磁盘I/O 15.2.15. InnoDB错误处理 15.2.16. 对InnoDB表的限制 15.2.17. InnoDB故障诊断与排除 15.3. MERGE存储引擎 15.3.1. MERGE表方面的问题 15.4. MEMORY (HEAP)存储引擎 15.5. BDB (BerkeleyDB)存储引擎 15.5.1. BDB支持的操作系统 15.5.2. 安装BDB 15.5.3. BDB启动选项 15.5.4. BDB表的特性 15.5.5. 修改BDB所需的事宜 15.5.6. 对BDB表的限制 15.5.7. 使用BDB表时可能出现的错误 15.6. EXAMPLE存储引擎 15.7. FEDERATED存储引擎 15.7.1. 安装FEDERATED存储引擎 15.7.2. FEDERATED存储引擎介绍 15.7.3. 如何使用FEDERATED表 15.7.4. FEDERATED存储引擎的局限性 15.8. ARCHIVE存储引擎 15.9. CSV存储引擎 15.10. BLACKHOLE存储引擎 16. 编写自定义存储引擎 16.1. 前言 16.2. 概述 16.3. 创建存储引擎源文件 NoName 16.5. 对处理程序进行实例化处理 16.6. 定义表扩展 16.7. 创建表 16.8. 打开表 16.9. 实施基本的表扫描功能 16.9.1. 实施store_lock()函数 16.9.2. 实施external_lock()函数 16.9.3. 实施rnd_init()函数 16.9.4. 实施info()函数 16.9.5. 实施extra()函数 16.9.6. 实施rnd_next()函数 16.10. 关闭表 NoName NoName NoName 16.14. API引用 16.14.1. bas_ext 16.14.2. close 16.14.3. create 16.14.4. delete_row 16.14.5. delete_table 16.14.6. external_lock 16.14.7. extra 16.14.8. info 16.14.9. open 16.14.10. rnd_init 16.14.11. rnd_next 16.14.12. store_lock 16.14.13. update_row 16.14.14. write_row 17. MySQL簇 17.1. MySQL簇概述 17.2. MySQL簇的基本概念 17.3. 多计算机的简单基础知识 17.3.1. 硬件、软件和联网 17.3.2. 安装 17.3.3. 配置 17.3.4. 首次启动 17.3.5. 加载示例数据并执行查询 17.3.6. 安全关闭和重启 17.4. MySQL簇的配置 17.4.1. 从源码创建MySQL簇 17.4.2. 安装软件 17.4.3. MySQL簇的快速测试设置 17.4.4. 配置文件 17.5. MySQL簇中的进程管理 17.5.1. 用于MySQL簇的MySQL服务器进程使用 17.5.2. ndbd,存储引擎节点进程 17.5.3. ndb_mgmd,“管理服务器”进程 17.5.4. ndb_mgm,“管理客户端”进程 17.5.5. 用于MySQL簇进程的命令选项 17.6. MySQL簇的管理 17.6.1. MySQL簇的启动阶段 17.6.2. “管理客户端”中的命令 17.6.3. MySQL簇中生成的事件报告 17.6.4. 单用户模式 17.6.5. MySQL簇的联机备份 17.7. 使用与MySQL簇的高速互连 17.7.1. 配置MySQL簇以使用SCI套接字 17.7.2. 理解簇互连的影响 17.8. MySQL簇的已知限制 17.9. MySQL簇发展的重要历程 17.9.1. MySQL 5.0中的MySQL簇变化 17.9.2. 关于MySQL簇的MySQL 5.1发展历程 17.10. MySQL簇常见问题解答 17.11. MySQL簇术语表 18. 分区 18.1. MySQL中的分区概述 18.2. 分区类型 18.2.1. RANGE分区 18.2.2. LIST分区 18.2.3. HASH分区 18.2.4. KEY分区 18.2.5. 子分区 18.2.6. MySQL分区处理NULL值的方式 18.3. 分区管理 18.3.1. RANGE和LIST分区的管理 18.3.2. HASH和KEY分区的管理 18.3.3. 分区维护 18.3.4. 获取关于分区的信息 19. MySQL中的空间扩展 19.1. 前言 19.2. OpenGIS几何模型 19.2.1. Geometry类的层次 19.2.2. 类Geometry 19.2.3. 类Point 19.2.4. 类Curve 19.2.5. 类LineString 19.2.6. 类Surface 19.2.7. 类Polygon 19.2.8. 类GeometryCollection 19.2.9. 类MultiPoint 19.2.10. 类MultiCurve 19.2.11. 类MultiLineString 19.2.12. 类MultiSurface 19.2.13. 类MultiPolygon 19.3. 支持的空间数据格式 19.3.1. 著名的文本(WKT)格式 19.3.2. 著名的二进制(WKB)格式 19.4. 创建具备空间功能的MySQL数据库 19.4.1. MySQL空间数据类型 19.4.2. 创建空间值 19.4.3. 创建空间列 19.4.4. 填充空间列 19.4.5. 获取空间数据 19.5. 分析空间信息 19.5.1. Geometry格式转换函数 19.5.2. Geometry函数 19.5.3. 从已有Geometry创建新Geometry的函数 19.5.4. 测试几何对象间空间关系的函数 19.5.5. 关于几何最小边界矩形(MBR)的关系 19.5.6. 测试几何类之间空间关系的函数 19.6. 优化空间分析 19.6.1. 创建空间索引 19.6.2. 使用空间索引 19.7. MySQL的一致性和兼容性 19.7.1. 尚未实施的GIS特性 20. 存储程序和函数 20.1. 存储程序和授权表 20.2. 存储程序的语法 20.2.1. CREATE PROCEDURE和CREATE FUNCTION 20.2.2. ALTER PROCEDURE和ALTER FUNCTION 20.2.3. DROP PROCEDURE和DROP FUNCTION 20.2.4.SHOW CREATE PROCEDURE和SHOW CREATE FUNCTION 20.2.5.SHOW PROCEDURE STATUS和SHOW FUNCTION STATUS 20.2.6. CALL语句 20.2.7. BEGIN ... END复合语句 20.2.8. DECLARE语句 20.2.9. 存储程序中的变量 20.2.10. 条件和处理程序 20.2.11. 光标 20.2.12. 流程控制构造 20.3. 存储程序、函数、触发程序和复制:常见问题 20.4. 存储子程序和触发程序的二进制日志功能 21. 触发程序 21.1. CREATE TRIGGER语法 21.2. DROP TRIGGER语法 21.3. 使用触发程序 22. 视图 22.1. ALTER VIEW语法 22.2. CREATE VIEW语法 22.3. DROP VIEW语法 22.4. SHOW CREATE VIEW语法 23. INFORMATION_SCHEMA信息数据库 23.1. INFORMATION_SCHEMA表 23.1.1. INFORMATION_SCHEMA SCHEMATA表 23.1.2. INFORMATION_SCHEMA TABLES表 23.1.3. INFORMATION_SCHEMA COLUMNS表 23.1.4. INFORMATION_SCHEMA STATISTICS表 23.1.5. INFORMATION_SCHEMA USER_PRIVILEGES表 23.1.6. INFORMATION_SCHEMA SCHEMA_PRIVILEGES表 23.1.7. INFORMATION_SCHEMA TABLE_PRIVILEGES表 23.1.8. INFORMATION_SCHEMA COLUMN_PRIVILEGES表 23.1.9. INFORMATION_SCHEMA CHARACTER_SETS表 23.1.10. INFORMATION_SCHEMA COLLATIONS表 23.1.11. INFORMATION_SCHEMA COLLATION_CHARACTER_SET_APPLICABILITY表 23.1.12. INFORMATION_SCHEMA TABLE_CONSTRAINTS表 23.1.13. INFORMATION_SCHEMA KEY_COLUMN_USAGE表 23.1.14. INFORMATION_SCHEMA ROUTINES表 23.1.15. INFORMATION_SCHEMA VIEWS表 23.1.16. INFORMATION_SCHEMA TRIGGERS表 23.1.17. 其他INFORMATION_SCHEMA表 NoName 24. 精度数学 24.1. 数值的类型 24.2. DECIMAL数据类型更改 24.3. 表达式处理 24.4. 四舍五入 24.5. 精度数学示例 25. API和库 25.1. libmysqld,嵌入式MySQL服务器库 25.1.1. 嵌入式MySQL服务器库概述 25.1.2. 使用libmysqld编译程序 25.1.3. 使用嵌入式MySQL服务器时的限制 25.1.4. 与嵌入式服务器一起使用的选项 25.1.5. 嵌入式服务器中尚需完成的事项(TODO) 25.1.6. 嵌入式服务器示例 25.1.7. 嵌入式服务器的许可 25.2. MySQL C API 25.2.1. C API数据类型 25.2.2. C API函数概述 25.2.3. C API函数描述 25.2.4. C API预处理语句 25.2.5. C API预处理语句的数据类型 25.2.6. C API预处理语句函数概述 25.2.7. C API预处理语句函数描述 25.2.8. C API预处理语句方面的问题 25.2.9. 多查询执行的C API处理 25.2.10. 日期和时间值的C API处理 25.2.11. C API线程函数介绍 25.2.12. C API嵌入式服务器函数介绍 25.2.13. 使用C API时的常见问题 25.2.14. 创建客户端程序 25.2.15. 如何生成线程式客户端 25.3. MySQL PHP API 25.3.1. 使用MySQL和PHP的常见问题 25.4. MySQL Perl API 25.5. MySQL C++ API 25.5.1. Borland C++ 25.6. MySQL Python API 25.7. MySQL Tcl API 25.8. MySQL Eiffel Wrapper 25.9. MySQL程序开发实用工具 25.9.1. msql2mysql:转换mSQL程序以用于MySQL 25.9.2. mysql_config:获取编译客户端的编译选项 26. 连接器 26.1. MySQL Connector/ODBC 26.1.1. MyODBC介绍 26.1.2. 关于ODBC和MyODBC的一般信息 26.1.3. 如何安装MyODBC 26.1.4. 在Windows平台上从二进制版本安装MyODBC 26.1.5. I在Unix平台上从二进制版本安装MyODBC 26.1.6. 在Windows平台上从源码版本安装MyODBC 26.1.7. 在Unix平台上从源码版本安装MyODBC 26.1.8. 从BitKeeper开发源码树安装MyODBC 26.1.9. MyODBC配置 26.1.10. 与MyODBC连接相关的事宜 26.1.11. MyODBC和Microsoft Access 26.1.12. MyODBC和Microsoft VBA及ASP 26.1.13. MyODBC和第三方ODBC工具 26.1.14. MyODBC通用功能 26.1.15. 基本的MyODBC应用步骤 26.1.16. MyODBC API引用 26.1.17. MyODBC数据类型 26.1.18. MyODBC错误代码 26.1.19. MyODBC与VB:ADO、DAO和RDO 26.1.20. MyODBC与Microsoft.NET 26.1.21. 感谢 26.2. MySQL Connector/NET 26.2.1. 前言 26.2.2. 下载并安装MySQL Connector/NET 26.2.3. Connector/NET体系结构 26.2.4. 使用MySQL Connector/NET 26.2.5. MySQL Connector/NET变更史 26.3. MySQL Connector/J 26.3.1. 基本的JDBC概念 26.3.2. 安装 Connector/J 26.3.3. JDBC引用 26.3.4. 与J2EE和其他Java框架一起使用 Connector/J 26.3.5. 诊断 Connector/J方面的问题 26.3.6. Changelog 26.4. MySQL Connector/MXJ 26.4.1. 前言 26.4.2. 支持平台: 26.4.3. Junit测试要求 26.4.4. 运行Junit测试 26.4.5. 作为JDBC驱动程序的一部分运行 26.4.6. 在Java对象中运行 26.4.7. MysqldResource API 26.4.8. 在JMX代理(custom)中运行 26.4.9. 部署在标准的JMX代理环境下 (JBoss) 26.4.10. 安装 27. 扩展MySQL 27.1. MySQL内部控件 27.1.1. MySQL线程 27.1.2. MySQL测试套件 27.2. 为MySQL添加新函数 27.2.1. 自定义函数接口的特性 27.2.2. CREATE FUNCTION/DROP FUNCTION语法 27.2.3. 添加新的自定义函数 27.2.4. 添加新的固有函数 27.3. 为MySQL添加新步骤 27.3.1. 步骤分析 27.3.2. 编写步骤 A. 问题和常见错误 A.1. 如何确定导致问题的原因 A.2. 使用MySQL程序时的常见错误 A.2.1. 拒绝访问 A.2.2. 无法连接到[local] MySQL服务器 A.2.3. 客户端不支持鉴定协议 A.2.4. 输入密码时出现密码错误 NoName A.2.6. 连接数过多 A.2.7. 内存溢出 A.2.8. MySQL服务器不可用 A.2.9. 信息包过大 A.2.10. 通信错误和失效连接 A.2.11. 表已满 A.2.12. 无法创建文件/写入文件 A.2.13. 命令不同步 A.2.14. 忽略用户 A.2.15. 表tbl_name不存在 A.2.16. 无法初始化字符集 A.2.17. 文件未找到 A.3. 与安装有关的事宜 A.3.1. 与MySQL客户端库的链接问题 A.3.2. 如何以普通用户身份运行MySQL A.3.3. 与文件许可有关的问题 A.4. 与管理有关的事宜 A.4.1. 如何复位根用户密码 A.4.2. 如果MySQL依然崩溃,应作些什么 A.4.3. MySQL处理磁盘满的方式 A.4.4. MySQL将临时文件储存在哪里 A.4.5. 如何保护或更改MySQL套接字文件/tmp/mysql.sock A.4.6. 时区问题 A.5. 与查询有关的事宜 A.5.1. 搜索中的大小写敏感性 A.5.2. 使用DATE列方面的问题 A.5.3. 与NULL值有关的问题 A.5.4. 与列别名有关的问题 A.5.5. 非事务表回滚失败 A.5.6. 从相关表删除行 A.5.7. 解决与不匹配行有关的问题 A.5.8. 与浮点比较有关的问题 A.6. 与优化器有关的事宜 A.7. 与表定义有关的事宜 A.7.1. 与ALTER TABLE有关的问题 A.7.2. 如何更改表中的列顺序 A.7.3. TEMPORARY TABLE问题 A.8. MySQL中的已知事宜 A.8.1. MySQL中的打开事宜 B. 错误代码和消息 B.1. 服务器错误代码和消息 B.2. 客户端错误代码和消息 C. 感谢 C.1. MySQL AB处的开发人 C.2. MySQL贡献人 C.3. 资料员和译员 C.4. MySQL使用和包含的库 C.5. 支持MySQL的软件包 C.6. 用于创建MySQL的工具 C.7. MySQL支持人员 D. MySQL变更史 D.1. 5.1.x版中的变更情况(开发) D.1.1. 5.1.2版中的变更情况(尚未发布) D.1.2. 5.1.1版中的变更情况(尚未发布) D.2. MyODBC的变更情况 D.2.1. MyODBC 3.51.12的变更情况 D.2.2. MyODBC 3.51.11的变更情况 E. 移植到其他系统 E.1. 调试MySQL服务器 E.1.1. 针对调试编译MySQL E.1.2. 创建跟踪文件 E.1.3. 在gdb环境下调试mysqld E.1.4. 使用堆栈跟踪 E.1.5. 使用日志文件找出mysqld中的错误原因 E.1.6. 如果出现表崩溃,请生成测试案例 E.2. 调试MySQL客户端 E.3. DBUG软件包 E.4. 关于RTS线程的注释 E.5. 线程软件包之间的差异 F. 环境变量 G. MySQL正则表达式 H. MySQL中的限制 H.1. 联合的限制 I. 特性限制 I.1. 对存储子程序和触发程序的限制 I.2. 对服务器端光标的限制 I.3. 对子查询的限制 I.4. 对视图的限制 I.5. 对XA事务的限制 J. GNU通用公共许可 K. MySQL FLOSS许可例外 索引
characters

第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

当服务器在运行时,快速备份MyISAMISAM表的工具。参见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可以压缩BLOBTEXT列。旧版本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存在则退出并提示错误。用--forcemyisampack则一定压缩表。

·-join=big_tbl_name-jbig_tbl_name

将命令行中的所有表联接为一个表big_tbl_name。将要连接的所有表必须有相等的结构(相同的列名和类型,相同的索引等等)

·--pack length=len-plen

指定记录长度存储大小,以字节计。值应为12或者3myisampack保存所有长度指针为12或者3字节的行。在大多数正常情况下,myisampack在开始压缩文件前可以确定准确的长度值,但在压缩过程中它可以提示它可能已经使用了一个短的长度。在这种情况下,myisampack输出一条提示,下次你压缩同一文件时,你可以使用更短的记录长度。

·--silent-s

沉默模式。只有发生错误时才写输出。

·--test-t

没有实际地压缩表,只是测试压缩。

·--tmpdir=path-Tpath

使用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: station
Isam-version: 2
Creation time: 1996-03-13 10:08:58
Recover time: 1997-02-02 3:06:43
Data records: 1192 Deleted blocks: 0
Datafile parts: 1192 Deleted data: 0
Datafile pointer (bytes): 2 Keyfile pointer (bytes): 2
Max datafile length: 54657023 Max keyfile length: 33554431
Recordlength: 834
Record format: Fixed length
table description:
Key Start Len Index Type Root Blocksize Rec/key
1 2 4 unique unsigned long 1024 1024 1
2 32 30 multip. text 10240 1024 1
Field Start Length Type
1 1 1
2 2 4
3 6 4
4 10 1
5 11 20
6 31 1
7 32 30
8 62 35
9 97 35
10 132 35
11 167 4
12 171 16
13 187 35
14 222 4
15 226 16
16 242 20
17 262 20
18 282 20
19 302 30
20 332 4
21 336 4
22 340 1
23 341 8
24 349 8
25 357 8
26 365 2
27 367 2
28 369 4
29 373 4
30 377 1
31 378 2
32 380 8
33 388 4
34 392 4
35 396 4
36 400 4
37 404 1
38 405 4
39 409 4
40 413 4
41 417 4
42 421 4
43 425 4
44 429 20
45 449 30
46 479 1
47 480 1
48 481 79
49 560 79
50 639 79
51 718 79
52 797 8
53 805 1
54 806 1
55 807 20
56 827 4
57 831 4
shell>myisampack station.MYI
Compressing station.MYI: (1192 records)
- Calculating statistics
normal: 20 empty-space: 16 empty-zero: 12 empty-fill: 11
pre-space: 0 end-space: 12 table-lookups: 5 zero: 7
Original trees: 57 After join: 17
- Compressing file
87.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: station
Isam-version: 2
Creation time: 1996-03-13 10:08:58
Recover time: 1997-04-17 19:04:26
Data records: 1192 Deleted blocks: 0
Datafile parts: 1192 Deleted data: 0
Datafile pointer (bytes): 3 Keyfile pointer (bytes): 1
Max datafile length: 16777215 Max keyfile length: 131071
Recordlength: 834
Record format: Compressed
table description:
Key Start Len Index Type Root Blocksize Rec/key
1 2 4 unique unsigned long 10240 1024 1
2 32 30 multip. text 54272 1024 1
Field Start Length Type Huff tree Bits
1 1 1 constant 1 0
2 2 4 zerofill(1) 2 9
3 6 4 no zeros, zerofill(1) 2 9
4 10 1 3 9
5 11 20 table-lookup 4 0
6 31 1 3 9
7 32 30 no endspace, not_always 5 9
8 62 35 no endspace, not_always, no empty 6 9
9 97 35 no empty 7 9
10 132 35 no endspace, not_always, no empty 6 9
11 167 4 zerofill(1) 2 9
12 171 16 no endspace, not_always, no empty 5 9
13 187 35 no endspace, not_always, no empty 6 9
14 222 4 zerofill(1) 2 9
15 226 16 no endspace, not_always, no empty 5 9
16 242 20 no endspace, not_always 8 9
17 262 20 no endspace, no empty 8 9
18 282 20 no endspace, no empty 5 9
19 302 30 no endspace, no empty 6 9
20 332 4 always zero 2 9
21 336 4 always zero 2 9
22 340 1 3 9
23 341 8 table-lookup 9 0
24 349 8 table-lookup 10 0
25 357 8 always zero 2 9
26 365 2 2 9
27 367 2 no zeros, zerofill(1) 2 9
28 369 4 no zeros, zerofill(1) 2 9
29 373 4 table-lookup 11 0
30 377 1 3 9
31 378 2 no zeros, zerofill(1) 2 9
32 380 8 no zeros 2 9
33 388 4 always zero 2 9
34 392 4 table-lookup 12 0
35 396 4 no zeros, zerofill(1) 13 9
36 400 4 no zeros, zerofill(1) 2 9
37 404 1 2 9
38 405 4 no zeros 2 9
39 409 4 always zero 2 9
40 413 4 no zeros 2 9
41 417 4 always zero 2 9
42 421 4 no zeros 2 9
43 425 4 always zero 2 9
44 429 20 no empty 3 9
45 449 30 no empty 3 9
46 479 1 14 4
47 480 1 14 4
48 481 79 no endspace, no empty 15 9
49 560 79 no empty 2 9
50 639 79 no empty 2 9
51 718 79 no endspace 16 9
52 797 8 no empty 2 9
53 805 1 17 1
54 806 1 3 9
55 807 20 no empty 3 9
56 827 4 no zeros, zerofill(2) 2 9
57 831 4 no zeros, zerofill(1) 2 9

myisampack显示下面的各种信息:

·normal

不需要进行额外压缩的列的数量。

·empty-space

只包含空格的列的数量;占一个比特。

·empty-zero

只包含二进制零的列的数量;占一个比特。

·empty-fill

不占该类全字节范围的整数列的数量;这些列被改为较小的类型。例如,如果所有值的范围为从-128127BIGINT(8个字节)可以保存为TINYINT(1个字节)

·pre-space

用引导空格保存的十进制列的数量。在这种情况下,每个值包含一个引导空格的数量计数。

·end-space

有大量结尾空格的列的数量。在这种情况下,每个值包含一个结尾空格的数量计数。

·table-lookup

该列只有少量的不同的值,在进行哈夫曼压缩前被转换为一个ENUM

·zero

所有值为零的列的数量。

·Original trees

哈夫曼树的最初数量。

·After join

联接树以节省一些头空间之后留下的哈夫曼树的数量。

表被压缩后,myisamchk -dvv为每列输出详细信息:

·Type

列的类型。该值可以包含下面的任何描述符:

oconstant

所有行具有相同的值。

ono endspace

不保存结尾空格。

ono endspacenot_always

不保存结尾空格并且对于所有的值不压缩结尾空格。

ono endspaceno empty

不保存结尾空格。不保存空值。

otable-lookup

列被转换为一个ENUM

ozerofill(n)

值中最有意义的n字节总为0,并且不保存。

ono zeros

不保存零。

oalways zeros

用一个位保存零值。

·Huff tree

列相关的哈夫曼树的数量。

·Bits

哈夫曼树使用的位数。

运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作:

shell>myisamchk -rq --sort-index --analyze tbl_name.MYI

将压缩的表安装到MySQL数据库目录中后,应执行mysqladmin flush-tables以强制mysqld使用新的表。

要想解压缩一个压缩的表,使用myisamchkisamchk--unpack选项。

8.3. mysql:MySQL命令行工具

8.3.1. 选项
8.3.2.mysql命令
8.3.3. 怎样从文本文件执行SQL语句
8.3.4.mysql技巧

mysql是一个简单的SQL外壳(GNUreadline功能)。它支持交互式和非交互式使用。当交互使用时,查询结果采用ASCII表格式。当采用非交互式(例如,用作过滤器)模式时,结果为tab分割符格式。可以使用命令行选项更改输出格式。

如果由于结果较大而内存不足遇到问题,使用--quick选项。这样可以强制mysql从服务器每次一行搜索结果,而不是检索整个结果集并在显示之前不得不将它保存到内存中。使用mysql_use_result()而不是mysql_store_result()来搜索结果集。

使用mysql很简单。从命令解释符提示来调用它:

shell>mysqldb_name

或:

shell>mysql --user=user_name--password=your_password db_name

这样输入一个SQL语句,用‘’、\g或者\G结尾并按回车键。

你可以这样运行一个脚本:

shell>mysqldb_name<script.sql>output.tab

8.3.1. 选项

mysql支持下面的选项:

·---help-

显示帮助消息并退出。

·--batch-B

打印结果,使用tab作为列间隔符,每个行占用新的一行。使用该选项,则mysql不使用历史文件。

·--character-sets -dir=path

字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。

·--compress-C

压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。

·---database=db_name-Ddb_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,-estatement

执行语句并退出。默认输出格式与用--batch产生的相同。4.3.1节,“在命令行上使用选项”中提供了一些例子。

·--force-f

即使出现一个SQL错误仍继续。

·--host=host_name-hhost_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环境变量的值。合法pagerslessmorecat [>filename]等等。该选项只在Unix中工作。不能以批处理模式工作。在8.3.2节,“mysql命令”中详细讨论了输出分页。

·--password[=password]-p[password]

当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password-p选项后面没有 密码值,则提示输入一个密码。在SysV-based UNIX系统中应省略密码,因为密码可以显示在ps的输出中。

·--port=port_num-Pport_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

只允许那些使用键值指定行生效的UPDATEDELETE语句。如果已经在选项文件中设置了该选项,可以用命令行中的--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-Spath

用于连接的套接字文件。

·--tables-t

用表格式显示输出。这是交互式应用的默认设置,但可用来以批处理模式产生表输出。

·--tee=file_name

将输出拷贝添加到给定的文件中。该选项在批处理模式不工作。在8.3.2节,“mysql命令”中详细讨论了Tee文件。

·--unbuffered-n

每次查询后刷新缓存区。

·--user=user_name-uuser_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-updatesSELECT语句的自动限制。(默认值是1,000

也可以使用--set-variable=var_name=valueor-Ovar_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>helpList 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的转义符。

Editnopagerpagersystem命令只在Unix中工作。

status命令提供连接和使用的服务器相关的部分信息。如果用--safe-updates模式运行,status也打印影响查询的MySQL变量的值。

要想记录查询及其输出,应使用tee命令。屏幕上显示的所有数据被追加到给定的文件后面。这对于调试也很有用。可以用--tee选项在命令行中启用该特性,或者用tee命令交互式启用。可以用notee命令交互式禁用tee文件。再次执行tee可以重新启用日志。前面的文件使用时不带任何参数。请注意执行完每个语句后tee可以将查询结果刷新到一个文件中,并且在mysql打印下一个提示前刷新。

--pager选项,可以用交互式模式使用Unix程序,例如lessmore或者其它类似的程序,来浏览或搜索查询结果。如果未指定该选项的值,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将结果显示在屏幕上。

还可以结合使用teepager函数。启用一个tee文件并将pager设置为less,能够使用less程序浏览结果,并且仍然可以同时将内容添加到一个文件中。结合pager命令使用的Unixteemysql嵌入式tee命令的差别是即使没有可用的Unixtee,嵌入式tee仍然可以工作。嵌入式tee还可以记录在屏幕上输出的内容,而结合pager命令使用的Unixtee不能记录那么多的内容。并且,可以从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字符格式(MonTue...)

\P

am/pm

\o

当前的月,数字格式

\O

当前的月,3字符格式(JanFeb...)

\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]> prompt
Returning to default PROMPT of mysql>
mysql>

8.3.3. 怎样从文本文件执行SQL语句

mysql客户程序一般交互使用:

shell>mysqldb_name

还可以将SQL语句放到一个文件中然后告诉mysql从该文件读取输入。要想实现,创建一个文本文件text_file,并包含你想要执行的语句。然后按如下所示调用mysql

shell>mysqldb_name<text_file

还可以用一个USEdb_name语句启动文本文件。在这种情况下,不需要在命令行中指定数据库名:

shell>mysql < text_file

如果正运行mysql,可以使用source\.命令执行SQL脚本文件:

mysql>sourcefilename
mysql>\.filename

有时想要使用脚本来向用户显示进度信息;为此可以插入下述行:

SELECT '' AS ' '

将输出

关于批处理模式的详细信息,参见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"  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 FROMtbl_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语句有下面的效果:

·不允许你执行UPDATEDELETE语句,除非在WHERE子句中指定一个键值约束或提供一个LIMIT子句(或二者皆使用)。例如:

·UPDATEtbl_nameSETnot_key_column=valWHEREkey_column=val;
·
·UPDATEtbl_nameSETnot_key_column=valLIMIT 1;

·所有大的SELECT结果自动限制到1,000行,除非语句包括一个LIMIT子句。

·放弃可能需要检查1,000,000多行组合的多表SELECT语句。

要将限制指定为1,0001,000,000之外的值,可以使用--select_limit--max_join_size选项覆盖默认值:

shell>mysql --safe-updates --select_limit=500 --max_join_size=10000

8.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 away
No connection. Trying to reconnect...
Connection id: 1
Current 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:用于检查访问权限的客户端

mysqlaccessYves CarlierMySQL分发提供的一个诊断工具。它检查访问权限的主机名、用户名和数据库组合。请注意mysqlaccess检查只使用userdbhost表的访问。它不检查在tables_privcolumns_privprocs_priv表中指定的表、列或者程序的权限。

调用mysqlaccess的方法:

shell>mysqlaccess [host_name[user_name[db_name]]] [options]

mysqlaccess理解下面的选项:

·---help-

显示帮助消息并退出。

·--brief-b

生成单行表格式的报告。

·--commit

从临时表将新访问权限复制到原授权表。必须为新的权限刷新授权表以使其生效。(例如,执行mysqladmin RELOAD命令)

·--copy

从原授权表重载临时授权表。

·--db=db_name-ddb_name

指定数据库名。

·---debug=N

指定调试级别。N可以为从03的一个整数。

·--host=host_name-hhost_name

在访问权限中使用的主机名。

·--howto

显示一些例子显示如何使用mysqlaccess

·--old_server

假定服务器是一个旧版本的MySQL服务器(MySQL 3.21之前),还不知道如何处理全WHERE子句。

·--password[=password]-p[password]

当连接服务器时使用的密码。如果你在命令行中在--password-p选项后面省略 密码值,将提示你输入密码。

·--plan

显示将来发布的建议和思想。

·--preview

更改临时授权表后显示权限的不同。

·--relnotes

显示发布注解。

·--rhost=host_name-Hhost_name

连接给定主机的MySQL服务器。

·--rollback

取消对临时授权表的最新的更改。

·--spassword[=password]-P[password]

super用户连接服务器时使用的密码。如果在命令行中在--password-p选项后面省略了 密码值,将提示你输入密码。

·--superuser=user_name-Uuser_name

指定以super用户连接时的用户名。

·--tables-t

生成表格式的报告。

·--user=user_name-uuser_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支持下面的命令:

·createdb_name

创建一个名为db_name的新数据库。

·debug

告诉服务器向错误日志写入调试信息。

·dropdb_name

删除名为db_nam的数据库和所有表。

·extended-status

显示服务器状态变量及其值。

·flush-hosts

刷新主机缓存中的所有信息。

·flush-logs

刷新所有日志。

·flush-privileges

重载授权表(类似reload)

·flush-status

清除状态变量。

·flush-tables

刷新所有表。

·flush-threads

刷新线程缓存。

·kill id,id,...

杀掉服务器线程。

·old-passwordnew-password

类似password但使用旧的(pre-4.1)密码哈希格式保存 密码。(参见5.7.9节,“MySQL 4.1中的密码哈希处理”)

·passwordnew-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 ...refreshreload命令的数量。

·Open tables

目前打开的表的数量。

·Memory in use

mysqld代码直接分配的内存数量。只有用--with--debug=full编译了MySQL该值才显示。

·Maximum memory used

mysqld代码直接分配的最大内存数量。只有用--with--debug=full编译了MySQL该值才显示。

如果当使用Unix套接字文件连接本地服务器时执行mysqladmin shutdownmysqladmin将等待直到服务器的进程ID文件被删除,以确保服务器正确停止。

mysqladmin支持下面的选项:

·---help-

显示帮助消息并退出。

·--character-sets-dir=path

字符集的安装目录。参见5.10.1节,“数据和排序用字符集”。

·--compress-C

压缩客户和服务器之间发送的所有信息(如果二者均支持压缩)。

·--count=num-cnum

迭代数目。该选项只有结合--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-hhost_name

连接给定主机上的MySQL服务器。

·--password[=password]-p[password]

连接服务器使用的密码。如果使用短选项形式(-p),该选项和 密码之间不能有空格。如果你在命令行中在--password-p选项后面省略 密码值,将提示你输入密码。

·--port=port_num-Pport_num

用于连接的TCP/IP端口号。

·--protocol={TCP | SOCKET | PIPE | MEMORY}

使用的连接协议。

·--relative-r

当带-I使用时显示当前和前面值的差别。目前,该选项只用于extended-status命令。

·--silent-s

如果不能建立与服务器的连接则以沉默方式退出。

·--sleep=delay-idelay

每睡眠delay秒后执行一次命令。

·--socket=path-Spath

用于连接的套接字文件。

·--user=user_name-uuser_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-Ovar_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-ddb_name

只列出该数据库的条目(只用本地日志)

·--force-read-f

使用该选项,如果mysqlbinlog读它不能识别的二进制日志事件,它会打印警告,忽略该事件并继续。没有该选项,如果mysqlbinlog读到此类事件则停止。

·--hexdump-H

在注释中显示日志的十六进制转储。该输出可以帮助复制过程中的调试。在MySQL 5.1.2中添加了该选项。

·--host=host_name-hhost_name

获取给定主机上的MySQL服务器的二进制日志。

·--local-load=path-lpat

为指定目录中的LOAD DATA INFILE预处理本地临时文件。

·--offset=N-oN

跳过前N个条目。

·--password[=password]-p[password]

当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password-p选项后面没有 密码值,则提示输入一个密码。

·--port=port_num-P port_num

用于连接远程服务器的TCP/IP端口号。

·--position=N-jN

不赞成使用,应使用--start-position

·--protocol={TCP | SOCKET | PIPE | -position

使用的连接协议。

·--read-from-remote-server-R

MySQL服务器读二进制日志。如果未给出该选项,任何连接参数选项将被忽略。这些选项是--host--password--port--protocol--socket--user

·--result-file=name,-rname

将输出指向给定的文件。

·--short-form-s

只显示日志中包含的语句,不显示其它信息。

·--socket=path-Spath

用于连接的套接字文件。

·--start-datetime=datetime

从二进制日志中第1个日期时间等于或晚于datetime参量的事件开始读取。datetime值相对于运行mysqlbinlog的机器上的本地时区值格式应符合DATETIMETIMESTAMP数据类型。例如:

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-uuser_name

连接远程服务器时使用的MySQL用户名。

·--version-V

显示版本信息并退出。

还可以使用--var_name=value选项设置下面的变量:

·open_files_limit

指定要保留的打开的文件描述符的数量。

可以将mysqlbinlog的输出传到mysql客户端以执行包含在二进制日志中的语句。如果你有一个旧的备份,该选项在崩溃恢复时也很有用(参见5.9.1节,“数据库备份”)

shell>mysqlbinloghostname-bin.000001 | mysql

或:

shell>mysqlbinloghostname-bin.[0-9]* | mysql

如果你需要先修改含语句的日志,还可以将mysqlbinlog的输出重新指向一个文本文件。(例如,想删除由于某种原因而不想执行的语句)。编辑好文件后,将它输入到mysql程序并执行它包含的语句。

mysqlbinlog有一个--position选项,只打印那些在二进制日志中的偏移量大于或等于某个给定位置的语句(给出的位置必须匹配一个事件的开始)。它还有在看见给定日期和时间的事件后停止或启动的选项。这样可以使用--stop-datetime选项进行点对点恢复(例如,能够说“将数据库前滚动到今天10:30 AM的位置)

如果MySQL服务器上有多个要执行的二进制日志,安全的方法是在一个连接中处理它们。下面是一个说明什么是不安全的例子:

shell>mysqlbinloghostname-bin.000001 | mysql # DANGER!!
shell>mysqlbinloghostname-bin.000002 | mysql # DANGER!!

使用与服务器的不同连接来处理二进制日志时,如果第1个日志文件包含一个CREATE TEMPORARY TABLE语句,第2个日志包含一个使用该临时表的语句,则会造成问题。当第1mysql进程结束时,服务器撤销临时表。当第2mysql进程想使用该表时,服务器报告 “不知道该”。

要想避免此类问题,使用一个连接来执行想要处理的所有二进制日志中的内容。下面提供了一种方法:

shell>mysqlbinloghostname-bin.000001hostname-bin.000002 | mysql

另一个方法是:

shell>mysqlbinloghostname-bin.000001 > /tmp/statements.sql
shell>mysqlbinloghostname-bin.000002 >> /tmp/statements.sql
shell>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

上述命令的输出应类似:

;
;
# 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 startup
ROLLBACK;

十六进制转储的输出包含下面的元素:

·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 aFORMAT_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 TABLEREPAIR TABLEANALYZE TABLEOPTIMIZE TABLE的方式。它确定在要执行的操作中使用使用哪个语句,然后将语句发送到要执行的服务器上。

3种方式来调用mysqlcheck

shell>mysqlcheck[options]db_name[tables]
shell>mysqlcheck[options] ---databaseDB1[DB2DB3...]
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-hhost_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-Spath

用于连接的套接字文件。

·--tables

覆盖---database-B选项。选项后面的所有参量被视为表名。

·--user=user_name-uuser_name

当连接服务器时使用的MySQL用户名。

·--verbose-v

冗长模式。打印关于各阶段程序操作的信息。

·--version-V

显示版本信息并退出。

8.8. mysqldump:数据库备份程序

mysqldump客户端可用来转储数据库或搜集数据库进行备份或将数据转移到另一个SQL服务器(不一定是一个MySQL服务器)。转储包含创建表和/或装载表的SQL语句。

如果你在服务器上进行备份,并且表均为MyISAM表,应考虑使用mysqlhotcopy,因为可以更快地进行备份和恢复。参见8.9节,“mysqlhotcopy:数据库备份程序”。

3种方式来调用mysqldump

shell>mysqldump [options]db_name[tables]
shell>mysqldump [options] ---databaseDB1[DB2DB3...]
shell>mysqldump [options] --all--database

如果没有指定任何表或使用了---database--all--database选项,则转储整个数据库。

要想获得你的版本的mysqldump支持的选项,执行mysqldump ---help

如果运行mysqldump没有--quick--opt选项,mysqldump在转储结果前将整个结果集装入内存。如果转储大数据库可能会出现问题。该选项默认启用,但可以用--skip-opt禁用。

如果使用最新版本的mysqldump程序生成一个转储重装到很旧版本的MySQL服务器中,不应使用--opt-e选项。

mysqldump支持下面的选项:

·---help-

显示帮助消息并退出。

·--add-drop--database

在每个CREATE DATABASE语句前添加DROP DATABASE语句。

·--add-drop-tables

在每个CREATE TABLE语句前添加DROP TABLE语句。

·--add-locking

LOCK TABLESUNLOCK TABLES语句引用每个表转储。重载转储文件时插入得更快。参见7.2.16节,“INSERT语句的速度”。

·--all--database-A

转储所有数据库中的所有表。与使用---database选项相同,在命令行中命名所有数据库。

·--allow-keywords

允许创建关键字列名。应在每个列名前面加上表名前缀。

·---comments[={0|1}]

如果设置为0,禁止转储文件中的其它信息,例如程序版本、服务器版本和主机。--skipcomments---comments=0的结果相同。 默认值为1,即包括额外信息。

·--compact

产生少量输出。该选项禁用注释并启用--skip-add-drop-tables--no-set-names--skip-disable-keys--skip-add-locking选项。

·--compatible=name

产生与其它数据库系统或旧的MySQL服务器更兼容的输出。值可以为ansimysql323mysql40postgresqloraclemssqldb2maxdbno_key_optionsno_tables_options或者no_field_options。要使用几个值,用逗号将它们隔开。这些值与设置服务器SQL模式的相应选项有相同的含义。参见5.3.2节,“SQL服务器模式”。

该选项不能保证同其它服务器之间的兼容性。它只启用那些目前能够使转储输出更兼容的SQL模式值。例如,--compatible=oracle不映射Oracle类型或使用Oracle注释语法的数据类型。

·--complete-insert-c

使用包括列名的完整的INSERT语句。

·--compress-C

压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。

·--create-option

CREATE TABLE语句中包括所有MySQL表选项。

·---database-B

转储几个数据库。通常情况,mysqldump将命令行中的第1个名字参量看作数据库名,后面的名看作表名。使用该选项,它将所有名字参量看作数据库名。CREATE DATABASE IF NOT EXISTSdb_nameUSEdb_name语句包含在每个新数据库前的输出中。

·---debug[=debug_options]-# [debug_options]

写调试日志。debug_options字符串通常为'd:t:o,file_name'

·--default-character-set=charset

使用charsetas默认字符集。参见5.10.1节,“数据和排序用字符集”。如果没有指定,mysqldump使用utf8

·--delayed-insert

使用INSERT DELAYED语句插入行。

·--delete-master-logs

在主复制服务器上,完成转储操作后删除二进制日志。该选项自动启用--master-data

·--disable-keys-K

对于每个表,用;;语句引用INSERT语句。这样可以更快地装载转储文件,因为在插入所有行后创建索引。该选项只适合MyISAM表。

·--extended-insert-e

使用包括几个VALUES列表的多行INSERT语法。这样使转储文件更小,重载文件时可以加速插入。

·--fields-terminated-by=...--fields-enclosed-by=...--fields-optionally-enclosed-by=...--fields-escaped-by=...---terminated-by=...

这些选项结合-T选项使用,与LOAD DATA INFILE的相应子句有相同的含义。参见13.2.5节,“LOAD DATA INFILE语法”。

·--first-slave-x

不赞成使用,现在重新命名为--lock-all-tables

·--flush-logs-F

开始转储前刷新MySQL服务器日志文件。该选项要求RELOAD权限。请注意如果结合--all--database(-A)选项使用该选项,根据每个转储的数据库刷新日志。例外情况是当使用--lock-all-tables--master-data的时候:在这种情况下,日志只刷新一次,在所有 表被锁定后刷新。如果你想要同时转储和刷新日志,应使用--flush-logs连同--lock-all-tables--master-data

·--force-f

在表转储过程中,即使出现SQL错误也继续。

·--host=host_name-hhost_name

从给定主机的MySQL服务器转储数据。默认主机是localhost

·--hex-blob

使用十六进制符号转储二进制字符串列(例如,'abc'变为0x616263)。影响到的列有BINARYVARBINARYBLOB

·--lock-all-tables-x

所有数据库中的所有表加锁。在整体转储过程中通过全局读锁定来实现。该选项自动关闭--single-transaction--lock-tables

·--lock-tables-l

开始转储前锁定所有表。用READ LOCAL锁定表以允许并行插入MyISAM表。对于事务表例如InnoDBBDB--single-transaction是一个更好的选项,因为它不根本需要锁定表。

请注意当转储多个数据库时,--lock-tables分别为每个数据库锁定表。因此,该选项不能保证转储文件中的表在数据库之间的逻辑一致性。不同数据库表的转储状态可以完全不同。

·--master-data[=value]

该选项将二进制日志的位置和文件名写入到输出中。该选项要求有RELOAD权限,并且必须启用二进制日志。如果该选项值等于1,位置和文件名被写入CHANGE MASTER语句形式的转储输出,如果你使用该SQL转储主服务器以设置从服务器,从服务器从主服务器二进制日志的正确位置开始。如果选项值等于2CHANGE MASTER语句被写成SQL注释。如果value被省略,这是默认动作。

--master-data选项启用--lock-all-tables,除非还指定--single-transaction(在这种情况下,只在刚开始转储时短时间获得全局读锁定。又见--single-transaction。在任何一种情况下,日志相关动作发生在转储时。该选项自动关闭--lock-tables

·--no-create-db-n

该选项禁用CREATE DATABASE db_name语句,如果给出---database--all--database选项,则包含到输出中。

·--no-create-info-t

不写重新创建每个转储表的CREATE TABLE语句。

·--no-data-d

不写表的任何行信息。如果你只想转储表的结构这很有用。

·--opt

该选项是速记;等同于指定--add-drop-tables--add-locking --create-option --disable-keys--extended-insert --lock-tables --quick --set-charset。它可以给出很快的转储操作并产生一个可以很快装入MySQL服务器的转储文件。该选项默认开启,但可以用--skip-opt禁用。要想只禁用确信用-opt启用的选项,使用--skip形式;例如,--skip-add-drop-tables--skip-quick

·--password[=password]-p[password]

连接服务器时使用的密码。如果你使用短选项形式(-p)不能在选项和密码之间有一个空格。如果在命令行中,忽略了--password-p选项后面的 密码值,将提示你输入一个。

·--port=port_num-P port_num

用于连接的TCP/IP端口号。

·--protocol={TCP | SOCKET | PIPE | MEMORY}

使用的连接协议。

·--quick-q

该选项用于转储大的表。它强制mysqldump从服务器一次一行地检索表中的行而不是检索所有行并在输出前将它缓存到内存中。

·--quote-names-Q

用‘`’字符引用数据库、表和列名。如果服务器SQL模式包括ANSI_QUOTES选项,用‘"’字符引用名。默认启用该选项。可以用--skip-quote-names禁用,但该选项应跟在其它选项后面,例如可以启用--quote-names--compatible

·--result-file=file-rfile

将输出转向给定的文件。该选项应用在Windows中,因为它禁止将新行‘\n’字符转换为‘\r\n’回车、返回/新行序列。

·--routines-R

在转储的数据库中转储存储程序(函数和程序)。使用---routines产生的输出包含CREATE PROCEDURECREATE FUNCTION语句以重新创建子程序。但是,这些语句不包括属性,例如子程序定义者或创建和修改时间戳。这说明当重载子程序时,对它们进行创建时定义者应设置为重载用户,时间戳等于重载时间。

如果你需要创建的子程序使用原来的定义者和时间戳属性,不使用--routines。相反,使用一个具有mysql数据库相应权限的MySQL账户直接转储和重载mysql.proc表的内容。

该选项在MySQL 5.1.2中添加进来。在此之前,存储程序不转储。

·--set-charset

SET NAMESdefault_character_set加到输出中。该选项默认启用。要想禁用SET NAMES语句,使用--skip-set-charset

·--single-transaction

该选项从服务器转储数据之前发出一个BEGINSQL语句。它只适用于事务表,例如InnoDBBDB,因为然后它将在发出BEGIN而没有阻塞任何应用程序时转储一致的数据库状态。

当使用该选项时,应记住只有InnoDB表能以一致的状态被转储。例如,使用该选项时任何转储的MyISAMHEAP表仍然可以更改状态。

--single-transaction选项和--lock-tables选项是互斥的,因为LOCK TABLES会使任何挂起的事务隐含提交。

要想转储大的表,应结合--quick使用该选项。

·--socket=path-Spath

当连接localhost(为默认主机)时使用的套接字文件。

·--skip--comments

参见---comments选项的描述。

·--tab=path-Tpath

产生tab分割的数据文件。对于每个转储的表,mysqldump创建一个包含创建表的CREATE TABLE语句的tbl_name.sql文件,和一个包含其数据的tbl_name.txt文件。选项值为写入文件的目录。

默认情况,.txt数据文件的格式是在列值和每行后面的新行之间使用tab字符。可以使用--fields-xxx----xxx选项明显指定格式。

注释:该选项只适用于mysqldumpmysqld服务器在同一台机器上运行时。你必须具有FILE权限,并且服务器必须有在你指定的目录中有写文件的许可。

·--tables

覆盖---database-B选项。选项后面的所有参量被看作表名。

·--triggers

为每个转储的表转储触发器。该选项默认启用;用--skip-triggers禁用它。

·--tz-utc

在转储文件中加入SET TIME_ZONE='+00:00'以便TIMESTAMP列可以在具有不同时区的服务器之间转储和重载。(不使用该选项,TIMESTAMP列在具有本地时区的源服务器和目的服务器之间转储和重载)--tz-utc也可以保护由于夏令时带来的更改。--tz-utc默认启用。要想禁用它,使用--skip-tz-utc。该选项在MySQL 5.1.2中加入。

·--user=user_name-uuser_name

连接服务器时使用的MySQL用户名。

·--verbose-v

冗长模式。打印出程序操作的详细信息。

·--version-V

显示版本信息并退出。

·--where='where-condition',-w 'where-condition'

只转储给定的WHERE条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。

例如:

"--where=user='jimf'"
"-wuserid>1"
"-wuserid<1"

·--xml-X

将转储输出写成XML

还可以使用--var_name=value选项设置下面的变量:

·max_allowed_packet

客户端/服务器之间通信的缓存区的最大大小。最大为1GB

·net_buffer_length

客户端/服务器之间通信的缓存区的初始大小。当创建多行插入语句时(如同使用选项--extended-insert--opt)mysqldump创建长度达net_buffer_length的行。如果增加该变量,还应确保在MySQL服务器中的net_buffer_length变量至少这么大。

还可以使用--set-variable=var_name=value-Ovar_name=value语法设置变量。然而,现在不赞成使用该语法。

mysqldump最常用于备份一个整个的数据库:

shell>mysqldump --optdb_name>backup-file.sql

你可以这样将转储文件读回到服务器:

shell>mysqldb_name<backup-file.sql

或者为:

shell>mysql -e "source /path-to--backup/backup-file.sql"db_name

mysqldump也可用于从一个MySQL服务器向另一个服务器复制数据时装载数据库:

shell>mysqldump --optdb_name| mysql --host=remote_host-Cdb_name

可以用一个命令转储几个数据库:

shell>mysqldump ---databasedb_name1[db_name2...] > my_databases.sql

如果你想要转储所有数据库,使用--all--database选项:

shell>mysqldump --all-databases > all_databases.sql

如果表保存在InnoDB存储引擎中,mysqldump提供了一种联机备份的途径(参见下面的命令)。该备份只需要在开始转储时对所有表进行全局读锁定(使用FLUSH TABLES WITH READ LOCK)。获得锁定后,读取二进制日志的相应内容并将锁释放。因此如果并且只有当发出FLUSH...时正执行一个长的更新语句,MySQL服务器才停止直到长语句结束,然后转储则释放锁。因此如果MySQL服务器只接收到短("短执行时间")的更新语句,即使有大量的语句,也不会注意到锁期间。

shell>mysqldump --all-databases --single-transaction > all_databases.sql

对于点对点恢复(也称为“前滚”,当你需要恢复旧的备份并重放该备份以后的更改时),循环二进制日志(参见5.11.3节,“二进制日志”)或至少知道转储对应的二进制日志内容很有用:

shell>mysqldump --all-databases --master-data=2 > all_databases.sql
shell>mysqldump --all-databases --flush-logs --master-data=2 > all_databases.sql

如果表保存在InnoDB存储引擎中,同时使用--master-data--single-transaction提供了一个很方便的方式来进行适合点对点恢复的联机备份。

关于备份的详细信息,参见5.9.1节,“数据库备份”。

8.9. mysqlhotcopy:数据库备份程序

mysqlhotcopy是一个Perl脚本,最初由Tim Bunce编写并提供。它使用LOCK TABLESFLUSH TABLEScpscp来快速备份数据库。它是备份数据库或单个表的最快的途径,但它只能运行在数据库目录所在的机器上。mysqlhotcopy只用于备份MyISAM。它运行在UnixNetWare中。

shell>mysqlhotcopydb_name[/path/to/new_directory]
shell>mysqlhotcopydb_name_1...db_name_n/path/to/new_directory

备份给定数据库中的匹配正则表达式的表:

shell>mysqlhotcopydb_name./regex/

加上发音符(~)前缀,表名的正则表达式可以被否定:

shell>mysqlhotcopydb_name./~regex/

mysqlhotcopy支持下面的选项:

·---help-

显示帮助消息并退出。

·--allowold

如果目标存在不放弃(加上一个_old后缀重新命名它)

·--checkpoint=db_name.tbl_name

在指定的db_name.tbl_name插入检查点条目。

·---debug

启用调试输出。

·--dryrun-n

报告动作而不执行它们。

·--flushlog

所有表锁定后刷新日志。

·--keepold

完成后不删除以前(重新命名的)的目标。

·-- method=command

复制方法(cpscp)

·--noindices

备份中不包括全部索引文件。这样使备份更小、更快。可以在以后用myisamchk -rq重新构建索引。

·--password=password-ppassword

当连接服务器时使用的密码。请注意该选项的密码值是不可选的,不象其它MySQL程序。

·--port=port_num-P port_num

当连接本地服务器时使用的TCP/IP端口号。

·--quiet-q

除了出现错误时保持沉默。

·--regexp=expr

复制所有数据库名匹配给出的正则表达式的数据库。

·--socket=path-Spath

用于连接的Unix套接字文件。

·--suffix=str

所复制的数据库名的后缀。

·--tmpdir=path

临时目录(代替/tmp)

·--user=user_name-uuser_name

当连接服务器时使用的MySQL用户名。

mysqlhotcopy从选项文件读取[client][mysqlhotcopy]选项组。

要想执行mysqlhotcopy,你必须可以访问备份的表文件,具有那些表的SELECT权限和RELOAD权限(以便能够执行FLUSH TABLES)

使用perldoc调用其它mysqlhotcopy文档:

shell>perldoc mysqlhotcopy

8.10. mysqlimport:数据导入程序

mysqlimport客户端提供了LOAD DATA INFILEQL语句的一个命令行接口。mysqlimport的大多数选项直接对应LOAD DATA INFILE子句。参见13.2.5节,“LOAD DATA INFILE语法”。

这样调用mysqlimport

shell>mysqlimport [options]db_nametextfile1[textfile2...]

对于在命令行中命名的每个文本文件,mysqlimport去掉文件名的扩展名并使用结果来确定将导入文件内容的表名。例如,文件patient.txtpatient.textpatient均将导入表patient

mysqlimport支持下面的选项:

·---help-

显示帮助消息并退出。

·--columns=column_list,-ccolumn_list

该选项采用用逗号分隔的列名作为其值。列名的顺序指示如何匹配数据文件列和表列。

·--compress-C

压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。

·---debug[=debug_options]-# [debug_options]

写调试日志。debug_options字符串通常是'd:t:o,file_name'

·--delete-D

导入文本文件前清空表。

·--fields-terminated-by=...--fields-enclosed-by=...--fields-optionally-enclosed-by=...--fields-escaped-by=...--lines-terminated-by=...

这些选项与LOAD DATA INFILE相应子句的含义相同。参见13.2.5节,“LOAD DATA INFILE语法”。

·--force-f

忽视错误。例如,如果某个文本文件的表不存在,继续处理其它文件。不使用--force,如果表不存在则mysqlimport退出。

·--host=host_name-hhost_name

将数据导入给定主机上的MySQL服务器。默认主机是localhost

·--ignore-i

参见--replace选项的描述。

·--ignore-lines=n

忽视数据文件的前n行。

·--local-L

从本地客户端读入输入文件。

·--lock-tables-l

处理文本文件前锁定所有表以便写入。这样可以确保所有表在服务器上保持同步。

·--password[=password]-p[password]

当连接服务器时使用的密码。如果使用短选项形式(-p),选项和 密码之间不能有空格。如果在命令行中--password-p选项后面没有 密码值,则提示输入一个密码。

·--port=port_num-P port_num

用于连接的TCP/IP端口号。

·--protocol={TCP | SOCKET | PIPE | MEMORY}

使用的连接协议。

·--replace-r

--replace--ignore选项控制复制唯一键值已有记录的输入记录的处理。如果指定--replace,新行替换有相同的唯一键值的已有行。如果指定--ignore,复制已有的唯一键值的输入行被跳过。如果不指定这两个选项,当发现一个复制键值时会出现一个错误,并且忽视文本文件的剩余部分。

·--silent-s

沉默模式。只有出现错误时才输出。

·--socket=path-Spath

当连接localhost时使用的套接字文件(为默认主机)

·--user=user_name-uuser_name

当连接服务器时MySQL使用的用户名。

·--verbose-v

冗长模式。打印出程序操作的详细信息。

·--version-V

显示版本信息并退出。

这里是一个示例会话,显示如何使用mysqlimport

shell>mysql -e 'CREATE TABLE imptest(id INT, n VARCHAR(30))' test
shell>ed
a
100 Max Sydow
101 Count Dracula
.
w imptest.txt
32
q
shell>od -c imptest.txt
0000000 1 0 0 \t M a x S y d o w \n 1 0
0000020 1 \t C o u n t D r a c u l a \n
0000040
shell>mysqlimport --local test imptest.txt
test.imptest: Records: 2 Deleted: 0 Skipped: 0 Warnings: 0
shell>mysql -e 'SELECT * FROM imptest' test
+------+---------------+
| id | n |
+------+---------------+
| 100 | Max Sydow |
| 101 | Count Dracula |
+------+---------------+

8.11. mysqlshow-显示数据库、表和列信息

mysqlshow客户可用来很快地查找存在哪些数据库,数据库中的表,表中的列或索引。

mysqlshow为一些SQL显示语句提供了一个命令行界面。相同的信息可以通过直接使用那些语句获得。例如,你可以从mysql客户程序发出它们。参见13.5.4节,“SHOW语法”。

象这样调用mysqlshow

shell>mysqlshow[选项] [db_name[tbl_name[col_name]]]

·如果没有给出数据库,显示所有匹配的数据库。

·如果没有给出表,显示数据库中所有匹配的表。

·如果没有给出列,显示表中所有匹配的列和列类型。

请注意,在MySQL的新版本中,你只能看到有部分权限的那些数据库、表或者列。

如果最后的参数包含shellSQL通用字符(*’、‘?’、‘%’或者‘_),只显示那些名匹配通用字符的名字。如果一个数据库名包含下划线,应该使用一个反斜线(部分Unix shells需要双反斜线)对它们进行转义,以便得到一个正确的表或列的列表。‘*’和‘?’字符被转换为SQL的‘%’和‘_’通用字符。你试图用‘_’显示一个表的列名时,这可能会造成一些混淆,因为在这种情况下mysqlshow显示与模式相匹配的表名。这很容易通过在命令行添加一个‘%’参量来解决。

mysqlshow支持下面的选项:

·---help-

显示一个帮助消息并退出。

·--character-sets-dir=path

字符集安装目录。参见5.10.1节,“数据和排序用字符集”。

·--compress-C

压缩所有的客户和服务器之间发送的信息(如果它们都支持压缩)。

·---debug[=debug_options]-# [debug_options]

写调试日志。debug_options字符串通常是'd:t:o,file_name'

·--default-character-set=charset

使用charset为默认字符集。参见5.10.1节,“数据和排序用字符集”。

·--host=host_name-hhost_name

在给出的主机上连接MySQL服务器。

·--keys, -k

显示表索引。

·--password[=password]-p[password]

连接服务器时使用的密码。如果你使用短选项形式(-p)不能在选项和 密码之间有一个空格。如果在命令行中,你忽略了--password-p选项后面的 密码值,将提示你输入一个。

·--port=port_num, -Pport_num

连接时使用的TCP/IP端口号。

·--protocol={TCP | SOCKET | PIPE | MEMORY}

连接时使用的协议。

·--show-table-type

显示一列来指示表类型,与SHOW FULL TABLES语句显示相同。

·--socket=path-Spath

当连接localhost时使用的套接字文件(它时默认主机)。

·--status, -i

显示关于每个表的额外信息。

·--user=user_name-uuser_name

连接服务器时使用的MySQL用户名。

·--verbose-v

冗长模式。打印出程序操作的详细信息。该选项可以多次使用以便增加信息总量。

·--version-V

显示版本信息并退出。

8.12. myisamlog:显示MyISAM日志文件内容

myisamlog处理MyISAM日志文件内容。

象这样调用myisamlog

shell>myisamlog [options] [logfile-name[tbl_name] ...]

常用操作是更新(-u)。如果恢复完成(-r,所有写和可能的更新以及删除操作完成并且只统计错误。如果没有给出日志文件名,使用myisam.log作为日志文件名。如果在命令行中指定了表名,只更新那些指定的表。

myisamlog理解下面的选项:

·-?-I

显示一个帮助消息并退出。

·-cN

只执行N个命令。

·-fN

指定打开文件的最大数目。

·-Ffilepath/

TODO

·-i

退出之前显示详细信息。

·-ooffset

指定起始偏移量。

·-pN

从路径中移除N个组件。

·-r

恢复。

·-Rrecord-pos-file record-pos

指定记录位置文件和记录位置。

·-u

更新。

·-v

Verbose模式。产生更多输出。该选项可以多次使用以便产生越来越多的输出。

·-wwrite-file

指定写文件。

·-V

显示版本信息。

8.13. perror:解释错误代码

对于大多数系统错误,除内部文本信息之外,MySQL还按下面的风格显示的系统错误代码:

message ... (errno: #)

message ... (Errcode: #)

通过检查系统文档或使用perror工具,可以检查错误代码的意义。

perror为系统错误代码或存储引擎(表处理)错误代码打印其描述信息。

象这样调用perror

shell>perror [options]errorcode...

例如:

shell>perror13 64

Error code 13: Permission denied

Error code 64: Machine is not on the network

注释:要想显示MySQL簇的错误代码,用--ndb选项调用perror

shell>perror --ndberrorcode

请注意,系统错误信息的含义可能与操作系统有关。在不同的操作系统中错误代码的含义可能不同。

8.14. replace:字符串替换实用工具

replace实用工具可以及时更改文件或标准输入中的字符串。它首先使用有限状态机来匹配长的字符串。该工具可以用来交换字符串。例如,下面的命令交换给定文件file1file2中的ab

shell>replace a b b a -- file1 file2 ...

使用--选项来指示字符串-替换列表的结束位置和开始的文件名。

在命令行中的任何文件名被及时修改,因此在转换之前,可能要对源文件进行备份。

如果在命令行中没有指定文件名,replace读取标准输入并写到标准输出中。在这种情况下,不需要--选项。

replace程序用于msql2mysql参见25.9.1节,“msql2mysql:转换mSQL程序以用于MySQL”。

replace支持下面的选项:

·-?-I

显示一条帮助消息并退出。

·-#debug_options

写调试日志。debug_options字符串通常是'd:t:o,file_name'

·-s

沉默模式。打印出程序执行的少量信息。

·-v

冗长模式。打印出程序执行的大量信息。

·-V

显示版本信息并退出。

8.15. mysql_zap:杀死符合某一模式的进程

mysql_zap杀死匹配某一模式的进程。象这样调用它:

shell>mysql_zap [-signal] [-?Ift]pattern

如果进程的ps命令的输出行包含该模式,则认为其匹配。默认情况,mysql_zap对每个进程请求确认。响应y则杀死该进程,或者q退出mysql_zap。对于其它响应,mysql_zap不试图杀死进程。

如果给出-signal选项,它指定发送到每个进程的信号名或信号编号。否则,mysql_zap首先尝试TERM(信号15)然后用KILL(信号9)。

mysql_zap理解下面的额外选项:

·---help-?-I

显示一条帮助消息并退出。

·-f

强制模式。mysql_zap视图杀死每个匹配的进程而不需要确认。

·-t

测试模式。显示每个进程的信息但不杀死它。


这是MySQL参考手册的翻译版本,关于MySQL参考手册,请访问dev.mysql.com。 原始参考手册为英文版,与英文版参考手册相比,本翻译版可能不是最新的。

Previous article: Next article: