mybatis-主要几个组件

mybatis-主要几个组件

mysql主要组件说明

  • SqlSession - 作为 MyBatis 工作的主要顶层 API,表示和数据库交互的会话,完成必要数据库增删改查功能。
  • Executor - MyBatis 执行器,是 MyBatis 调度的核心,负责 SQL 语句的生成和查询缓存的维护。
  • StatementHandler - 封装了 JDBC Statement 操作,负责对 JDBC statement 的操作,如设置参数、将 Statement 结果集转换成 List 集合。
  • ParameterHandler - 负责对用户传递的参数转换成 JDBC Statement 所需要的参数。
  • ResultSetHandler - 负责将 JDBC 返回的 ResultSet 结果集对象转换成 List 类型的集合。
  • TypeHandler - 负责 java 数据类型和 jdbc 数据类型之间的映射和转换。
  • MappedStatement - MappedStatement 维护了一条 <select|update|delete|insert> 节点的封装。
  • SqlSource - 负责根据用户传递的 parameterObject,动态地生成 SQL 语句,将信息封装到 BoundSql 对象中,并返回。
  • BoundSql - 表示动态生成的 SQL 语句以及相应的参数信息。
  • Configuration - MyBatis 所有的配置信息都维持在 Configuration 对象之中。

完整sql语句位置(重要)

寻找完整sql语句思路

1.总结mybatis组件 , sql最总肯定在 excutor 执行器类里面执行

2.找 excutor 执行器接口的实现类 , 最后找到 SimpleExecutor 实现类

3.mybatis 是 jdbc 再次封装 , jdbc 使用 statment 传输 sql

4.所以在 excutor 执行器里面寻找 对应的 statment 拓展类

5.最终在 SimpleExcutor 里面 找到最终的 sql

SimpleExecutor.java

注意这个类 ClientPreParedStatement

com.mysql.cj.jdbc.ClientPreparedStatement: insert into user (id, name, age,
address, email)
values (null, ‘lubu’, 18,
‘nanjing’, ‘1111111111@qq.com’)

面试总结

今天面试有的问题没有完整总结

1.sql语言的分类

DQL(Data Query Language):数据查询语⾔ select 相关语句

DML(Data Manipulate Language):数据操作语⾔ insert 、update、delete 语句

DDL(Data De>ine Languge):数据定义语⾔ create、drop、alter 语句

TCL(Transaction Control Language):事务控制语⾔ set autocommit=0、start
transaction、savepoint、commit、rollback

2.springmvc执行流程

image-20220607150820430

.springmvc执行流程

[外链图片转存中…(img-wZl8qS9O-1654586252418)]

其余问题后面继续总结

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值