当前位置: 首页 > wzjs >正文

如何制作网站app网站建设制作过程

如何制作网站app,网站建设制作过程,任务发布平台,网站建设通讯设备中企动力1. 什么是统计信息? 统计信息就像是数据库的"地图",它告诉优化器: 每个表有多大(有多少行数据) 每个索引的"区分度"(有多少不同的值) 数据分布情况(哪些值出…

1. 什么是统计信息?

统计信息就像是数据库的"地图",它告诉优化器:

  • 每个表有多大(有多少行数据)

  • 每个索引的"区分度"(有多少不同的值)

  • 数据分布情况(哪些值出现频率高)

2. 为什么需要统计信息?

想象你要找一本图书馆的书:

  • 没有统计信息:盲目地在每个书架搜索

  • 有统计信息:直接去最可能存放的书架查找

二、统计信息核心内容全景图

统计信息类型存储位置更新方式影响范围
表大小/行数data_dictionary自动/手动ANALYZE全表扫描成本计算
索引基数(Cardinality)mysql.innodb_index_stats自动/手动ANALYZE索引选择
直方图(Histogram)column_statistics手动ANALYZE TABLE等值查询优化
索引深度内存计算自动范围查询效率

 

三、统计信息全生命周期管理

1. 创建阶段

 

-- 创建表时指定统计信息策略
CREATE TABLE users (id INT PRIMARY KEY,name VARCHAR(100),INDEX (name)
) STATS_PERSISTENT=1 STATS_AUTO_RECALC=1;

 

2. 更新机制

自动更新触发条件

  • 表中数据变化超过10%(默认阈值)

  • 第一次打开表时

  • 执行SHOW TABLE STATUS时(某些版本)

手动更新方法

-- 标准语法
ANALYZE TABLE users;-- 更新直方图统计(MySQL 8.0+)
ANALYZE TABLE users UPDATE HISTOGRAM ON name WITH 32 BUCKETS;

 3. 监控方法

-- 检查统计信息时效性
SELECT table_name,update_time,CONCAT(ROUND(data_length/1024/1024,2),'MB') AS size,IF(DATEDIFF(NOW(),update_time)>7,'⚠️过期','✅正常') AS status
FROM information_schema.tables
WHERE table_schema=DATABASE();-- 查看索引统计详情
SELECT * FROM mysql.innodb_index_stats WHERE table_name='users';

四、生产环境最佳实践

1. 参数配置建议

[mysqld]
# 启用持久化统计(重启不丢失)
innodb_stats_persistent=ON
# 自动重新计算统计
innodb_stats_auto_recalc=ON
# 增加采样页面提高准确性
innodb_stats_persistent_sample_pages=32

2. 维护方案

日常维护

-- 每周维护脚本示例
SET @db = DATABASE();
SELECT CONCAT('ANALYZE TABLE ', table_name, ';') 
FROM information_schema.tables 
WHERE table_schema = @db AND DATEDIFF(NOW(),update_time) > 7
INTO OUTFILE '/tmp/analyze_tables.sql';
SOURCE /tmp/analyze_tables.sql;

大表特殊处理

# 使用pt-table-sync分批分析
pt-table-sync --analyze h=localhost,D=dbname,t=large_table

五、常见问题解决方案

1. 统计信息不准的症状

  • 执行计划突然变差

  • 相同的查询有时快有时慢

  • EXPLAIN显示预估行数与实际严重不符

2. 紧急处理方法

-- 立即刷新问题表的统计信息
FLUSH TABLE users;
ANALYZE TABLE users;-- 强制使用指定索引(临时方案)
SELECT /*+ INDEX(users name_idx) */ * FROM users WHERE name LIKE 'A%';

3. 自动化监控方案

-- 创建监控事件
CREATE EVENT monitor_stats
ON SCHEDULE EVERY 1 DAY
DO
BEGINDECLARE cnt INT;SELECT COUNT(*) INTO cnt FROM information_schema.tables WHERE table_schema=DATABASE() AND DATEDIFF(NOW(),update_time)>7;IF cnt > 0 THEN-- 发送报警邮件或记录日志CALL send_alert(CONCAT(cnt, ' tables need analyze'));END IF;
END;

六、可视化学习工具

  1. 统计信息查看

    -- 使用MySQL Workbench可视化统计信息
    -- 右键表 → Table Inspector → Indexes/Statistics
  2. 执行计划对比

    -- 更新统计前后对比
    EXPLAIN FORMAT=TREE SELECT * FROM users WHERE age > 30;
    ANALYZE TABLE users;
    EXPLAIN FORMAT=TREE SELECT * FROM users WHERE age > 30;

http://www.dtcms.com/wzjs/574281.html

相关文章:

  • 企业网站托管新趋势wordpress显示数据库请求
  • 亚马逊电子商务网站的建设会展策划与管理
  • 做网站 异地域名做qa和helpful的网站
  • 报名入口网站建设基础网络建设
  • ps怎么做网站一寸的照片行业网站怎么做
  • 网站开发重要性网站建设内容清单
  • 南京网站设计公司济南兴田德润优惠吗网站开发哪家专业
  • python做网站视频typecho前端建站工具
  • 中国建设银行晋中分行网站网站建设产品分类
  • 简单小网站WordPress菜单调用不出
  • 温州模板网站建站网页编辑工具2022
  • 建设厅网站的秘钥怎么买网站运营一般做那些分析
  • 高频网站开发广州网站排名优化费用
  • 东平网站制作哪家好防疫站24小时在线咨询
  • 地图制作网站自己做一个网站需要多少钱
  • 免费 建站怀集网站建设
  • 广州 网站建设天元建设集团有限公司单位
  • 设计公司网站天津实体店网站建设
  • 网站建设的服务器网络架构有几种模式
  • 网站建设是做什么邢台搜
  • 怎么给自己做网站吗知乎 做网站的公司 中企动力
  • 做网站前怎么写文档wordpress主题 双站点
  • 建设企业网站首页邯郸百度公司咋样
  • 网站源码地址怎么看青岛seo网站推广
  • 优秀网站做的比较好的美食网站
  • 网站设计稿一般尺寸做网站需要多少钱卖片可以吗
  • 建设信用卡网银网站东莞技术支持网站建设专家
  • 网站轮播广告动画怎么做微信推广网站建设
  • 网站建设5iec怎么制作手机网页
  • 网络营销实验网站建设心得绍兴市建设局网站