同时存url和url_hash列
#建表 create table t10 ( id int primary key, url char(60) not null default '' ); #插入数据 insert into t10 values (1,'http://www.baidu.com'), (2,'http://www.sina.com'), (3,'http://www.sohu.com.cn'), (4,'http://www.onlinedown.net'), (5,'http://www.gov.cn'); #修改表结构,添加urlcrc列 alter table t10 add urlcrc int unsigned not null;
在存储的时候,将url对应的crc32码一同插入到数据库中,然后按照urlcrc字段建立索引,然后查找的时候,我们在业务层中将对应的url转换为crc32进行查找,就可以利用上索引了。
因为crc的结果是32位int无符号数,因此当数据超过40亿,也会有重复,但这是值得的.(索引长度为int4个字节)
多列索引
多列索引的考虑因素—列的查询频率 , 列的区分度, 注意一定要结合实际业务场景
以ecshop商城为例, goods表中的cat_id,brand_id,做多列索引,从区分度看,brand_id区分度更高, 但从 商城的实际业务业务看, 顾客一般先选大分类->小分类->品牌,最终选择建立2个索引:
(1)index(cat_id,brand_id)
(2)index(cat_id,shop_price)
甚至可以再加 (3)index(cat_id,brand_id,shop_price),3个冗余索引
但(3)中的前2列和(1)中的前2列一样,所以可以再去掉(1),建立2个索引
index(cat_id,price)
和 index(cat_id,brand_id,shop_price);
更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL索引操作技巧汇总》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》
希望本文所述对大家MySQL数据库计有所帮助。
更多ECSHOP内容来自木庄网络博客
标签:ECSHOP
相关阅读 >>
基于discuz security.inc.php代码的深入分析
更多相关阅读请进入《ECSHOP》频道 >>