Mapper 怎么能找到实体和数据库

一、一句话先给结论(先有整体感)

Mapper 能找到实体和数据库,靠的是这 4 件事:

  1. Mapper 接口被 Spring 扫描成 Bean

  2. Mapper 接口 ↔ XML 的 namespace / 方法名 对应

  3. SQL 执行结果 ↔ 实体字段 映射

  4. DataSource + SqlSessionFactory 决定"连哪个数据库"

二、Mapper 是怎么"被 Spring 发现"的?

1️⃣ Mapper 本质是什么?

复制代码
public interface UserInfoMapper {
    String querySystemUser();
}

注意一句话:

Mapper 接口没有实现类,但运行时却能调用

为什么?

2️⃣ @MapperScan 做了什么?

在 Spring Boot 启动类里(或配置类):

复制代码
@SpringBootApplication
@MapperScan("。。。。。")
public class Application {
}

它做了三件事:

  1. 扫描包

  2. 发现所有 Mapper 接口

  3. 给每个接口生成一个"动态代理对象"

这个代理对象,才是真正被注入的 Bean。

复制代码
@Autowired
private UserInfoMapper userInfoMapper; // 注入的是代理对象

三、Mapper 是怎么"找到数据库"的?

1️⃣ 数据库连接是谁管的?

不是 Mapper。

DataSource

复制代码
spring:
  datasource:
    url: jdbc:postgresql://localhost:5432/xxx
    username: postgres
    password: ***

Spring Boot 自动帮你创建:

复制代码
DataSource
    ↓
SqlSessionFactory
    ↓
SqlSession

所有 Mapper 都共用这个 SqlSessionFactory

2️⃣ 所以 Mapper 干的事情其实只有一件:

"拿着 SQL → 通过 SqlSession → 用 DataSource 执行"

四、Mapper 方法是怎么找到 XML 里的 SQL 的?

Mapper 接口 XML
全限定名 namespace
方法名 select / update / insert 的 id
相关推荐
随风飘的云20 小时前
MySQL的慢查询优化解决思路
数据库
IvorySQL1 天前
PostgreSQL 技术日报 (3月7日)|生态更新与内核性能讨论
数据库·postgresql·开源
赵渝强老师1 天前
【赵渝强老师】金仓数据库的数据文件
数据库·国产数据库·kingbase·金仓数据库
随逸1771 天前
《Milvus向量数据库从入门到实战,手把手搭建语义检索系统》
数据库
神秘的猪头1 天前
🚀 React 开发者进阶:RAG 核心——手把手带你玩转 Milvus 向量数据库
数据库·后端·llm
IvorySQL2 天前
PostgreSQL 技术日报 (3月6日)|为什么 Ctrl-C 在 psql 里让人不安?
数据库·postgresql·开源
NineData2 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
IvorySQL2 天前
PostgreSQL 技术日报 (3月5日)|规划器控制力升级,内核能力再进阶
数据库·postgresql·开源
数据组小组3 天前
免费数据库管理工具深度横评:NineData 社区版、Bytebase 社区版、Archery,2026 年开发者该选哪个?
数据库·测试·数据库管理工具·数据复制·迁移工具·ninedata社区版·naivicat平替