当前位置: 首页 > 图文教程 > 数据库 > MYSQL > MySQL数据库中应当如何实施info()函数

MYSQL
MySQL数据库中部分数据损坏恢复过程
教你怎样实现MySQL数据库双机热备份
MySQL数据库中关于网络安全的解决方案
最佳措施 全面解决MySQL网络安全问题
教你怎样在两台MySQL数据库间实现同步
忘记了 MySQL 的 root 密码
妙用触发器有效管理MySQL数据库
MYSQL5重置root密码
妙用触发器有效的管理 MySQL数据库
Mysql5写中文乱码问题解决
在MySQL中增添新用户权限的方法简介
教你维护MySQL安装的安全性和完整性
MySQL服务器安装完之后如何调节性能
MySQL出击企业级市场 “自立为王”尚早
MySQL 5.0 数据库的新特性的存储过程
通过MySQL内置全文检索实现中文的相关检索
MySQL中多表操作和批处理详细介绍
Oracle和MySQL、PostgreSQL特性对比
Sphinx+MySQL全文检索架构和安装过程
Mysql教程:教你为root用户指定一个目录

MYSQL 中的 MySQL数据库中应当如何实施info()函数


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-17   浏览: 42 ::
收藏到网摘: n/a

执行表扫描操作之前,将调用info()函数,以便为优化程序提供额外信息。

优化程序所需的信息不是通过返回值给定的,你需填充存储引擎类的特定属性,当info()调用返回后,优化程序将读取存储引擎类。

除了供优化程序使用外,在调用info()函数期间,很多值集合还将用于SHOW TABLE STATUS语句。

在sql/handler.h中列出了完整的公共属性,下面给出了一些常见的属性:

以下为引用的内容:
ulonglong data_file_length;          
/* Length off data file */
ulonglong max_data_file_length;      
/* Length off data file */
ulonglong index_file_length;
ulonglong max_index_file_length;
ulonglong delete_length;             
/* Free bytes */
ulonglong auto_increment_value;
ha_rows records;                     
/* Records in table */
ha_rows deleted;                     
/* Deleted records */
ulong raid_chunksize;
ulong mean_rec_length;        
/* physical reclength */
time_t create_time;                  
/* When table was created */
time_t check_time;
time_t update_time;

对于表扫描,最重要的属性是“records”,它指明了表中的记录数。当存储引擎指明表中有0或1行时,或有2行以上时,在这两种情况下,优化程序的执行方式不同。因此,当你在执行表扫描之前不清楚表中有多少行时,应返回大于等于2的值,这很重要(例如,数据是在外部填充的)。