索引被用来快速找出在一个列上用一特定值的行。
 只要符合条件 能够快速查找就可以了
如果表有一个多列索引,任何最左面的索引前缀能被优化器使用以找出行。例如,如果你有一个3行列索引(col1,col2,col3),你已经索引了在(col1)、(col1,col2)和(col1,col2,col3)上的搜索能力。 如果列不构成索引的最左面前缀,MySQL不能使用一个部分的索引。假定你下面显示的SELECT语句: mysql> SELECT * FROM tbl_name WHERE col1=val1;
mysql> SELECT * FROM tbl_name WHERE col2=val2;
mysql> SELECT * FROM tbl_name WHERE col2=val2 AND col3=val3;
如果LIKE参数是一个不以一个通配符字符起始的一个常数字符串,MySQL也为LIKE比较使用索引。例如,下列SELECT语句使用索引: mysql> select * from tbl_name where key_col LIKE "Patrick%";
mysql> select * from tbl_name where key_col LIKE "Pat%_ck%";在第一条语句中,只考虑有"Patrick" <= key_col < "Patricl"的行。在第二条语句中,只考虑有"Pat" <= key_col < "Pau"的行。

解决方案 »

  1.   

    没人肯指导一下,还是分不够呀?
      

  2.   

    你主要应该关心的是你的索引是否设计的合理,根据你系统日常所要经常用到的检索来确定应该建立什么样的索引。索引并不是越多越好,太多的索引与不充分、不正确的索引对性能都无益,在表上建立的每个索引都会增加存储开销,索引对于插入、删除、更新操作也会增加处理开支
      

  3.   

    我主要是想问,全文索引大概会占用多大空间?
      

  4.   

    数据:索引=1:4,如果数据量多一些,不会继续是这个比例,呵呵!
      

  5.   

    谢谢数学家。
    分不够再加。
      

  6.   

    看来没有人有这方面的经验,结贴。