執(zhí)行表掃描操作之前,將調(diào)用info()函數(shù),以便為優(yōu)化程序提供額外信息。 優(yōu)化程序所需的信息不是通過返回值給定的,你需填充存儲引擎類的特定屬性,當info()調(diào)用返回后,優(yōu)化程序?qū)⒆x取存儲引擎類。 除了供優(yōu)化程序使用外,在調(diào)用info()函數(shù)期間,很多值集合
執(zhí)行表掃描操作之前,將調(diào)用info()函數(shù),以便為優(yōu)化程序提供額外信息。
優(yōu)化程序所需的信息不是通過返回值給定的,你需填充存儲引擎類的特定屬性,當info()調(diào)用返回后,優(yōu)化程序?qū)⒆x取存儲引擎類。
除了供優(yōu)化程序使用外,在調(diào)用info()函數(shù)期間,很多值集合還將用于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”,它指明了表中的記錄數(shù)。當存儲引擎指明表中有0或1行時,或有2行以上時,在這兩種情況下,優(yōu)化程序的執(zhí)行方式不同。因此,當你在執(zhí)行表掃描之前不清楚表中有多少行時,應返回大于等于2的值,這很重要(例如,,數(shù)據(jù)是在外部填充的)。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com