Mybatis

什么是 MyBatis ?

       MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

特点:

       与JDBC相近的持久化框架,运行效率高;提供灵活的查询方式,但需要自己写SQL语句;不会自动进行级联操作,需要使用SQL手动进行;需要考虑入参和出参的类型及其对应关系。

基础使用:

导入mybatis和mysql-connector-java依赖。

配置mybatis:

       该配置可在官网上找到,中文版!!很容易上手。

<environments>:可有多个子<environment>,default指向某一子<environment>。

<environment>:配置数据库连接。

<transcationManager>:事务管理器配置。

<dataSource>:配置数据库连接。

<mappers>:配置JavaBean映射文件所在位置。

JavaBean文件映射配置:


UserDTO的JavaBean


UserDTO的映射文件

<mapper>:namespace属性值不可少,用于识别不同的数据库操作。

<select>:查询方法,parameterType是入参的类型,ResultMap是最终的查询结果。

<resultMap>:配置返回结果的属性。

<id/>:表的主键属性。

<result>:表的非主键属性。

<association>:一对多关联表的属性。其中column为调用的查询方法的入参,javaType是关联表的Bean对象。select是对应的关联表的查询方法,组成为对应JavaBean映射文件的namespace+ "." +<select>的id属性值,详见下图。


BlogDTO的JavaBean



BlogDTO的映射文件

此例中user与blog是一对一关系、与photo是一对多关系;blog与content、photo为一对多关系;content与photo是一对多关系。此处<collection>表示为对应的JavaBean的集合。


ContentDTO的映射文件

由于不需要反向查询,因而注释了该属性。

ContentDTO的映射文件

由于content是一个集合,而photo也是一个集合,类似于多对多,此处的查询方法使用的是联合查询,否则会报错。

此处的注释是另一种实现,该方式将在下面进行介绍。


PhotoDTO的映射配置


PhotoDTO的映射文件

测试类:


测试类代码

首先获取类加载器的输入流从配置文件中读取mybatis配置,然后获取session(获取session时的参数表示采用自动提交事务的方式,不推荐!)。

调用selectOne方法,第一个参数为对应JavaBean的namespace值 + "." + <select>的id值,第二个参数为其一参数方法的入参。

xml配置的另一方式:

         将全部配置写在同一个映射文件中:



由此其余映射文件可不需配置。

开启缓存:

默认开启一级缓存,若需要开启二级缓存,只需在对应的映射文件中加入<cache/>标签。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容