为什么不把不同种类的东西放不同表中?你这1啊2啊什么的理解下来就是不同的东西,你这搞到一起去了要满足你查询条件的情况下索引估计不太好加(估计你实际条件甚至还有些group操作等),如果你这只是一张索引表的话那就另当别论了。
如果这是个索引表的话最好看下你实际执行的sql计划,一般情况下通过这个表做出筛选后应该剩的数据量很小,如果表上的索引得当的话应该是没太大问题的。
还有一点你可以考虑下,你所谓的两种查询最后都落在了所谓的搭配图上,如果你这个搭配图数据量很大(你千万级还算一般)或者写入很频繁可以考虑通过这个搭配图的标识id做分片(表)
因为当时没想到数据有这么多,只是刚试运行已经是千万了,预估会成百倍增长,所以肯定不适合,不过目前大半年预估是应该再50亿以内的数据量。
按你说的分表这样,关联join的话也会很慢的,因为实际业务比这复杂的多,它本身还要join 其他业务表。
目前考虑nosql的方案做整改。
@光明中的黑手: 分片中主要的就是要规避join,宁可做数据上的冗余也要把join干掉
nosql不能解决你的问题,如果建模不正确,索引不对就算全量到内存中一样不行的。
哦,是麽,不是很清楚这块技术,我去了解了解,谢谢!