1、优化sql和索引。
2、加缓存,memcached,redis。
3、以上都做了后,还是慢,就做主从复制或主主复制,读写分离,可以在应用层做,效率高,也可以用三方工具,第三方工具推荐360的atlas,其它的要么效率不高,要么没人维护。
4、以上都做了还是慢,不要想着去做切分,mysql自带分区表,先试试这个,对应用是透明的,无需更改代码,sql语句是需要针对分区表做优化的,sql条件中要带上分区条件的列,从而使查询定位到少量的分区上,否则就会扫描全部分区。
5、以上都做了,那就先做垂直拆分,其实就是根据模块的耦合度,将一个大的系统分为多个小的系统,也就是分布式系统。
6、水平切分,针对数据量大的表,这一步最麻烦,最能考验技术水平,要选择一个合理的shardingkey,为了有好的查询效率,表结构也要改动,做一定的冗余,应用也要改,sql中尽量带shardingkey,将数据定位到限定的表上去查,而不是扫描全部的表。
原因:在求和的取值单元格中含有非数值的其他字符中或者当存在不是数值格式的单元格时会被公式视作空值。
解决方法:
1、首先在求和结果单元格可以看到显示的有“#VALUE!”符号。
2、可以看到在A列单元格中含有不是数字的字符,导致在使用公式求和时取数错误。
3、如果将字符更改为数字,那么显示错误的求和单元格就会恢复正常求值结果。
4、另外如果在A列中的单元格是文本格式,可以看到数字的左上角显示绿色的三角形,在C列的求和结果中可以看到被当成了空值。
5、此时需要选中单元格点击黄色感叹号图标,选择“转换为数字”就可以正常求和了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)