问题介绍
创建数据库的索引,可以选择单列索引,也可以选择创建组合索引。
遇到如下这种情况,用户表(user)与部门表(dept)通过部门用户关联表(deptuser)连接起来,如下图所示:
data:image/s3,"s3://crabby-images/e36d4/e36d4e6f8fe1dd2732634cadd37f8eba36734e80" alt="表间关系"
问题就是,在这个关联表中该如何建立索引呢?
针对该表,有如下四种选择:
- 针对于user_uuid建立单列索引idx_user
- 针对于user_dept建立单列索引idx_dept
- 建立组合索引idx_user_dept,即(user_uuid,dept_uuid)
- 建立组合索引idx_dept_user,即(dept_uuid,user_uuid)
对关联表的查询,有如下四种情况:
1 | -- 一、人员查所属部门用and方式 |
测试验证
一.人员查所属部门用and方式
1.1 关联表无索引
data:image/s3,"s3://crabby-images/c58dd/c58dd66db251599d1dac70c617adef3ed44a8fff" alt=""
1.2 单索引 Idx_dept
data:image/s3,"s3://crabby-images/c14f5/c14f580950734fd81e07e1ad006e7b4d87f45ec6" alt=""
1.3 单索引 Idx_user
data:image/s3,"s3://crabby-images/01cbb/01cbb531622b0871cff8257c94fadca8bff0dd25" alt=""
1.4 组合索引 Idx_dept_user
data:image/s3,"s3://crabby-images/d6325/d6325505ffc2dcfae982975f6e57fe14c3be0076" alt=""
1.5 组合索引 Idx_user_dept
data:image/s3,"s3://crabby-images/b07b2/b07b2626987eae54f03e0bb64ae7067ec4ebd9a7" alt=""
1.6 所有都建立上
data:image/s3,"s3://crabby-images/3418f/3418f4460d1a61830bcaa6c3cf9066769a5d95d6" alt=""
二 、人员查所属部门用join方式
2.1 关联表无索引
data:image/s3,"s3://crabby-images/69045/69045c28bb193d1747280f05c229b673f69df6ff" alt=""
2.2 单索引 Idx_dept
data:image/s3,"s3://crabby-images/34da6/34da63360ceb47867287aec4cac9859961230446" alt=""
2.3 单索引 Idx_user
data:image/s3,"s3://crabby-images/9ef92/9ef92bb95f89b7e6f37aa86fe368585ccd50489b" alt=""
2.4 组合索引 Idx_dept_user
data:image/s3,"s3://crabby-images/102f0/102f0f92c1538bac2be464096e5514e8865bcb5a" alt=""
2.5 组合索引 Idx_user_dept
data:image/s3,"s3://crabby-images/48b51/48b511b0eeab8492ca6e6cb447b937fffe77fbd2" alt=""
2.6 所有都建立上
data:image/s3,"s3://crabby-images/5da1d/5da1d775d730e907051fad58133dab45f9067468" alt=""
三 、部门查人员用and方式
3.1 关联表无索引
data:image/s3,"s3://crabby-images/983c0/983c0e9f0b7bcdba89477234fc64cda8e6b07088" alt=""
3.2 单索引 Idx_dept
data:image/s3,"s3://crabby-images/22dc5/22dc5a545ae7f66437386b8dcc9a26d4b1132935" alt=""
3.3 单索引 Idx_user
data:image/s3,"s3://crabby-images/cdf74/cdf74f81db295db0a42237deea31b7e393e0695f" alt=""
3.4 组合索引 Idx_dept_user
data:image/s3,"s3://crabby-images/69ee8/69ee87f94874f9016aae9ba348e92a9d78109adf" alt=""
3.5 组合索引 Idx_user_dept
data:image/s3,"s3://crabby-images/58b39/58b394e0b055d33bc4e1645b82a4067558470b2d" alt=""
3.6 所有都建立上
data:image/s3,"s3://crabby-images/16da3/16da3b9777fff42bc67f7d4810638d5d28461227" alt=""
四 、部门查所属人员用join方式
4.1 关联表无索引
data:image/s3,"s3://crabby-images/b370e/b370e1d2fb4f9c1687e52bfbcc101cf2930b5647" alt=""
4.2 单索引 Idx_dept
data:image/s3,"s3://crabby-images/9e123/9e123bb60a73bb1085bea9278dd6cf29ae36d921" alt=""
4.3 单索引 Idx_user
data:image/s3,"s3://crabby-images/a14de/a14de4ceb970545804a7653cae76ede2cabfdb0c" alt=""
4.4 组合索引 Idx_dept_user
data:image/s3,"s3://crabby-images/80b4f/80b4f1870c9d739a20e12c8815f43e422ab8146c" alt=""
4.5 组合索引 Idx_user_dept
data:image/s3,"s3://crabby-images/17f74/17f7423d15601e114efeb47c7aa5ef12cf71226d" alt=""
4.6 所有都建立上
data:image/s3,"s3://crabby-images/bc2ef/bc2ef7a362803cd1269ed3efe595d07e5a2a3188" alt=""
结论
通过上面的实际测试结果可以得出如下结论:针对于该关联表分别针对于user_uuid与dept_uuid建立单列索引idx_user,idx_dept最优。
其中索引idx_user适用与通过人员ID查询出该人员所在的部门;索引idx_dept适用与通过部门查询出该部门下所属的人员。
其它
测试数据
Test.sql相关资料
data:image/s3,"s3://crabby-images/3ed5a/3ed5aeac30c1665c94a5b4b77605086ecab11f67" alt=""