oracle mysql sqlserver三种数据库的查看索引和新增普通索引sql语句
参考:https://wenku.baidu.com/view/94ca5e3056270722192e453610661ed9ad5155a7.html
项目⽬上有关某个表的数据总是性能不达标,分析后发现有条关于按条件count()数量的sql导致好⼏个功能性能很慢。
于是,做成了再内存中维护这个count值,只在第⼀次查数据库取值,后续相应的全部变更都更新内存,想着毕竟就⼀个值⽽已。
因为这个表业务意义很⼤,字段内存很长,1百万的记录数,耗时15s左右。
也确实是通过这种⽅式,使得很多接⼝耗时达标。
但是,提交代码,被review时,提醒说没必要内存维护,⼀句count()⽽已,where 条件⾥的字段如果是查⽤的条件,直接加索引就好。
是啊,我为啥要维护在内存中,因为业务复杂,维护在内存中的值要和很多接⼝去更新,这是很有风险的。
验证后发现,确实对where⾥的有意义字段,加索引后,性能⾮常棒,接近0.00 sec。
总结三种数据库新增普通索引和查看索引的sql:
这⾥的表名map_model 字段名map_status map_key 都已脱敏处理
-- mysql 查看索引
show index from map_model;
-- mysql 创建普通索引
alter table model add index index_map_status(map_status)
alter table model add index index_mapKey(map_key
-- oracle 查看索引
select * from user_indexes where table_name = 'MAP_MODEL';
-- oracle 创建普通索引
create index index_map_status on model(map_status);
create index index_map_key on model(map_key);
--------------------------------------------------------
-- sqlserver 查看索引
select b.name from sys.sysobjects a, sys.sysindexes b
where a.id = b.id and a.name = 'map_model';
-- sqlserver 创建普通索引
create index index_status on model(status);
create index index_map_Key on model(map_key)
“fool me once,shame on you. fool me twice, shame on me.”,翻译过来的意思是“愚弄我一次,是你坏;愚弄我两次,是我蠢”。