Mybatis
执行流程图
文章目录
- Mybatis
- 框架的概述
- 一、什么是 Mybatis?
- 二、MyBatis的使用步骤:
- 三、Mybaits 的优点
- 四、MyBatis 框架的缺点:
- 五 、MyBatis 框架适用场合:
- 六 、Mybatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?
- 七 、MyBatis 实现一对一有几种方式? 具体怎么操作的?
- 八 、MyBatis 实现一对多有几种方式, 怎么操作的?
- 九、Mybatis 的 Xml 映射文件中 ,的 不同的 Xml 映射文件 ,id 是否可以重复?
- 十、Mybatis 动态 sql 有什么用?执行原理?有哪些动 态sql ?
- 十一、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
- 总结
框架的概述
框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是被应用开发者定制的应用骨架。提示:以下是本篇文章正文内容,下面案例可供参考
一、什么是 Mybatis?
Mybatis是一个半ORM框架,它内部封装了JDBC,开发时只需要关注SQL语句本身,不需要花费精力去处理加载驱动、创建连接、创建statement等繁杂的过程。程序员直接编写原生态sql,可以严格控制sql执行性能,灵活度高。
二、MyBatis的使用步骤:
1、搭建环境
创建实体类与Mapper接口
创建核心配置文件
创建映射文件
2、读取配置文件
InputStream in = Resources.getResourceAsStream(“SqlMapConfig.xml”);
3、创建SQLSessionFactory工厂
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(in);
4、创建SQLSession
SqlSession sqlSession= factory.openSession(true);
5、创建Mapper接口的代理对象
IUserMapper userMapper = sqlSession.getMapper(IUserDao.class);
6、执行Mapper中的方法
7、释放资源
注意事项:
映射文件与DAO接口的命名没有强制要求,我们可以将它们命名为IUserDao或IUserMapper,通常用Mapper命名较为常见
映射文件的位置必须与Mapper接口的包结构相同
映射文件中的namespace属性必须是对应的Mapper接口的全限定名
映射文件中的SQL语句的id属性值必须是Mapper接口中的方法名
三、Mybaits 的优点
(1)基于 SQL 语句编程,相当灵活,不会对应用程序或者数据库的现有设计造成
任何影响,SQL 写在 XML 里,解除 sql 与程序代码的耦合,便于统一管理;提供 XML 标
签,支持编写动态 SQL 语句,并可重用。
(2)与 JDBC 相比,减少了 50%以上的代码量,消除了 JDBC 大量冗余的代码,
不需要手动开关连接;
(3)很好的与各种数据库兼容(因为 MyBatis 使用 JDBC 来连接数据库,所以只
要 JDBC 支持的数据库 MyBatis 都支持)。
(4)能够与 Spring 很好的集成;
(5)提供映射标签,支持对象与数据库的 ORM 字段关系映射;提供对象关系映射
标签,支持对象关系组件维护。
四、MyBatis 框架的缺点:
(1)SQL语句的编写工作量较大,尤其当字段多、关联表多时,对开发人员编写SQL语句的功底有一定要求。
(2)SQL语句依赖于数据库,导致数据库移植性差,不能随意更换数据库。
五 、MyBatis 框架适用场合:
(1)Mybatis专注于SQL本身,是一个足够灵活的DAO层解决方案。
(2)对性能的要求很高,或者需求变化较多的项目,如互联网项目,Mybatis将是不错的选择。
六 、Mybatis 是如何将 sql 执行结果封装为目标对象并返回的?都有哪些映射形式?
第一种是使用<resultMap>标签,逐一定义数据库列名和对象属性名之间
的映射关系。
第二种是使用sql列的别名功能,将列的别名书写为对象属性名。
七 、MyBatis 实现一对一有几种方式? 具体怎么操作的?
有联合查询和嵌套查询,联合查询是几个表联合查询,只查询一次,通过resultMap里面配置association节点配置一对一的类就可以完成;
八 、MyBatis 实现一对多有几种方式, 怎么操作的?
有联合查询和嵌套查询。联合查询是几个表联合查询,只查询一次,通过在resultMap里面的collection节点配置一对多的类就可以完成。
九、Mybatis 的 Xml 映射文件中 ,的 不同的 Xml 映射文件 ,id 是否可以重复?
不同的Xml映射文件,如果配置了namespace,那么id可以重复;如果没有配置,id不能重复;
十、Mybatis 动态 sql 有什么用?执行原理?有哪些动 态sql ?
Mybatis动态sql可以在Xml映射文件内,以标签的形式编写动态sql,执行原理是根据表达式的值。
Mybatis提供了9种动态sql标签:trim|where|set|foreach|if|choose|when|otherwise|bind。
十一、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里?
Hibernate属于全自动ORM映射工具,使用Hibernate查询关联对象或者关联集合对象是,可以根据对象关系模型直接获取,所以它是全自动的。
总结
以上就是对Mybatis的概括。
MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架,
MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解(实体和数据库的映射可以在XML中间中,也可以使用注解),将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。