logo
publist
写文章

简介

该用户还未填写简介

擅长的技术栈

云原生数据库linux

可提供的服务

暂无可提供的服务

查询加速:数据仓库 SQL 性能优化完全指南

问题表现业务影响技术原因报表加载慢用户体验差,等待焦虑全表扫描、数据倾斜定时任务超时数据延迟,影响下游资源竞争、不合理 Join资源消耗过高成本增加,影响其他任务数据膨胀、缺乏过滤并发能力差高峰时段系统崩溃锁竞争、资源瓶颈SQL 查询性能优化是数据仓库工程师的核心技能。通过系统性地应用本文介绍的方法,可以显著提升查询效率。核心优化原则原则说明减少数据量分区裁剪、列裁剪、谓词下推优化 Join小表广

文章图片
#数据仓库#sql#性能优化
MySQL索引失效大揭秘:为什么明明有索引却不用?

索引失效排查口诀:最左前缀不能少,函数计算要不了。隐式转换坑最大,LIKE前导全扫描。OR连接两边建,负向查询需谨慎。NULL/NOT NULL看分布,统计信息常更新。EXPLAIN是照妖镜,type extra仔细瞧。1️⃣ 先看type:ALL/index → 必须优化2️⃣ 再看key:NULL → 索引失效3️⃣ 三看rows:太大 → 过滤性差4️⃣ 最后Extra:filesort/t

文章图片
#mysql#adb#android
MySQL索引类型完全指南:B+Tree、Hash、全文、空间索引一网打尽

MySQL的索引类型丰富多样,理解每种索引的特点和适用场景是数据库优化的基本功。等值查询用B+Tree或Hash,范围排序用B+Tree,文本搜索用Full-Text,地理空间用R-Tree,唯一约束用Unique,覆盖查询用联合索引。实际开发中,80%的场景使用普通B+Tree索引就够了,剩下的20%特殊需求再考虑其他索引类型。使用EXPLAIN验证索引效果,避免过度索引,才能在性能和存储之间找

文章图片
#mysql#哈希算法#数据库
心有灵犀:全面解析 Java 线程间通信机制

要点说明共享内存消息传递BlockingQueue、管道流同步辅助异步编程核心原则避免忙等待、处理虚假唤醒、注意死锁Java 线程间通信主要分为共享内存(wait/notify、Lock/Condition、volatile)和消息传递(BlockingQueue、管道流)两大类,辅以 CountDownLatch、CyclicBarrier 等同步辅助工具。

文章图片
#java#开发语言
深入解析 Java 线程的生命周期

Java 线程的六种状态定义在NEW, // 新建,尚未启动RUNNABLE, // 可运行(就绪或运行中)BLOCKED, // 阻塞(等待锁)WAITING, // 无限等待TIMED_WAITING, // 限期等待TERMINATED // 已终止注意:Java 将操作系统层面的“就绪”和“运行”统一为RUNNABLE状态。fill:#333;important;important;fil

#java#python#开发语言
深入解析 Java 线程的生命周期

Java 线程的六种状态定义在NEW, // 新建,尚未启动RUNNABLE, // 可运行(就绪或运行中)BLOCKED, // 阻塞(等待锁)WAITING, // 无限等待TIMED_WAITING, // 限期等待TERMINATED // 已终止注意:Java 将操作系统层面的“就绪”和“运行”统一为RUNNABLE状态。fill:#333;important;important;fil

#java#python#开发语言
轻量级并发的革命:全面解析协程与 Java 的落地之路

协程(Coroutine)是一种可以在执行过程中主动暂停(suspend)并在之后恢复(resume)的函数或任务。特性线程协程调度方式操作系统抢占式调度用户态协作式调度创建开销高(毫秒级)极低(纳秒级)栈内存约 1MB约 数百字节 ~ KB级切换成本微秒级(内核态)纳秒级(用户态)最大数量数千 ~ 数万百万级适用场景CPU 密集型I/O 密集型、高并发fill:#333;important;im

文章图片
#java#开发语言
避坑指南:ConcurrentModificationException 的根源与解决方案

场景错误做法正确做法遍历删除或removeIf()遍历添加使用普通 for + 下标,或创建新列表多线程遍历多线程直接操作 ArrayList使用 CopyOnWriteArrayListsubList 使用修改原 list 后遍历 subList操作 subList 时不要动原 listforEach 删除ConcurrentModificationException 是 Java 集合框架的

文章图片
#java#开发语言
为什么 ConcurrentHashMap 对 null 说“不”?

原因详细说明重要性并发二义性get 返回 null 无法区分"key 不存在"和"value 为 null"⭐⭐⭐⭐⭐原子性缺失get + containsKey 不是原子操作,状态会在两次调用间变化⭐⭐⭐⭐⭐内部机制冲突内部使用特殊节点(ForwardingNode 等)其 key/value 为 null⭐⭐⭐⭐设计一致性与 Hashtable 保持一致,避免混淆⭐⭐⭐性能考量避免额外的 nu

文章图片
#java#开发语言
为什么 ConcurrentHashMap 对 null 说“不”?

原因详细说明重要性并发二义性get 返回 null 无法区分"key 不存在"和"value 为 null"⭐⭐⭐⭐⭐原子性缺失get + containsKey 不是原子操作,状态会在两次调用间变化⭐⭐⭐⭐⭐内部机制冲突内部使用特殊节点(ForwardingNode 等)其 key/value 为 null⭐⭐⭐⭐设计一致性与 Hashtable 保持一致,避免混淆⭐⭐⭐性能考量避免额外的 nu

文章图片
#java#开发语言
    共 440 条
  • 1
  • 2
  • 3
  • 44
  • 请选择