文章详情页
mysql - 查询 修改数据库优化问题吧
浏览:182日期:2022-06-13 10:40:30
问题描述
我有一张表 有几十万个数据 每次触发某个事件的话 都会对所以表进行查询 符合条件的话(大部分都会符合) 对表数据的某个字段进行修改(修改的数据每个都不一样) 请问怎么做效率最高 因为是新手 不是很懂 非常感谢
问题解答
回答1:第一有查詢,所以查詢的條件必須讓建立的索引起效。第二批量的修改,,修改索引必須起效。但假如絕大部分的數據符合你這樣的條件時候,索引比較容易失效,所以建議可以獲取所有符合的id值,跟個通過id值去更新數據
回答2:如果一个事件会引起几十万条 UPDATE 的话:
检查是否设计有问题;
如果设计是正确的,尝试增加 redis 等缓存层,再使用消息队列等异步方法去更新数据库表;
相关文章:
1. css - 使用blur()滤镜为什么有透明的效果2. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?3. Android下,rxJava+retrofit 并发上传文件和串行上传文件的效率为什么差不多?4. python的bs4如何筛选出h1标签中的内容5. javascript - 移动端H5页面禁止缩放了,在浏览器上仍然可以缩放6. docker gitlab 如何git clone?7. angular.js - 通过数据中children的个数自动生成能点击展开的div8. java - spring-data Jpa 不需要执行save 语句,Set字段就可以自动执行保存的方法?求解9. docker-compose 为何找不到配置文件?10. javascript - Vue.js2.0不能使用debounce后大伙一般是如何解决延迟请求的问题的呢。
排行榜
