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执行流程
.springmvc执行流程
[外链图片转存中…(img-wZl8qS9O-1654586252418)]
其余问题后面继续总结