标签: sql优化

11 篇文章

MyBatis-Plus中的like用法总结
MyBatis-Plus作为MyBatis的增强工具,提供了丰富的模糊查询方法,其中like、likeLeft、likeRight是最常用的三种模糊查询方式。本文将详细介绍这三种方法的区别、使用场景及最佳实践。 一、三种like方法的核心区别 方法名称SQL等价形式匹配方式适用场景likeLIKE '%keyword%'全模糊匹配查询包含指定关键字…
MyBatis foreach标签用法详解
在Java开发中,我们经常需要处理批量数据库操作。传统的一条条记录处理方式不仅效率低下,而且代码冗长。MyBatis的<foreach>标签为解决这一问题提供了优雅而强大的方案,能够极大简化批量操作和动态SQL的编写。 一、foreach标签基础:核心属性全解析 MyBatis的<foreach>标签允许在SQL语句中动态循…
SpringBoot多数据源配置与动态切换技术详解
一、多数据源应用场景 在实际开发中,SpringBoot应用连接多个数据库的需求日益普遍,主要应用于以下场景: 读写分离架构:主库负责写入,从库负责查询,QPS可提升3-5倍 业务分库:订单库、用户库分离,降低单库压力 多租户系统:每个租户独立数据库,实现数据隔离 异构数据库:MySQL + MongoDB混合使用,满足不同业务需求 二、核心实现方…
谈谈 InnoDB 引擎中的表级锁、页级锁、行级锁
一、InnoDB锁机制概述 MySQL InnoDB存储引擎通过多版本并发控制(MVCC)与锁机制协同工作,实现了高效的事务隔离与数据一致性保障。InnoDB支持多种锁类型,按粒度可分为表级锁、页级锁和行级锁,其中行级锁是InnoDB的核心特性,也是其区别于MyISAM等存储引擎的关键优势。 二、表级锁(Table-Level Locking) 2…
MySQL 乐观锁与悲观锁怎么实现?
在数据库并发控制中,乐观锁和悲观锁是两种核心的并发控制策略,它们分别适用于不同的业务场景。本文将详细介绍这两种锁机制在MySQL中的实现方式、适用场景以及实际应用案例。 一、悲观锁:先加锁再操作 1. 核心思想 悲观锁认为并发冲突随时可能发生,因此在访问数据前先对数据加锁,阻止其他事务修改数据,直到当前事务完成操作后才释放锁。 2. 实现方式 在M…
什么是数据库范式,为什么要反范式化设计?
一、什么是数据库范式? 数据库范式(Normal Form)是关系型数据库设计中的一系列规范化规则,旨在通过分解表结构、消除数据冗余,确保数据的一致性和完整性。范式理论将数据库设计分为多个等级,从第一范式到第五范式,每个等级都有更严格的规范要求。 1.1 第一范式(1NF) 第一范式是最基础的范式要求,核心规则是字段原子性——每个字段必须是不可再分…
MySQL中如何优化多表JOIN?
MySQL多表JOIN的优化是数据库性能调优的核心环节,主要从索引设计、驱动表选择、执行计划分析、SQL写法优化四个维度入手。 一、索引优化:JOIN性能的基石 关联字段必须建索引,这是JOIN优化的首要原则。被驱动表的JOIN字段如果没有索引,MySQL会执行全表扫描,性能急剧下降。例如,orders o JOIN users u ON o.us…
为什么互联网大厂不推荐使用多表 join?
互联网大厂不推荐使用多表JOIN,主要基于性能瓶颈、可扩展性差、与微服务架构冲突三大核心原因。在高并发、海量数据的互联网场景下,JOIN操作会产生大量中间结果集,消耗大量CPU和内存资源,容易成为慢查询拖垮数据库。在分库分表架构下,跨物理节点的JOIN查询变得异常复杂甚至无法执行,同时强依赖其他服务的数据库表进行JOIN也违反了微服务边界的封装性。…