程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> MySQL數據庫中應當如何實施info()函數

MySQL數據庫中應當如何實施info()函數

編輯:關於MYSQL數據庫

執行表掃描操作之前,將調用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的值,這很重要(例如,數據是在外部填充的)。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved