mybatis通用mapper的使用

       项目中持久层封装了两套,一个hibernate,一个是mybatis。hibernate中封装了一些通用的方法,但是mybatis中没有,基于这个需求开始使用mybatis的通用mapper。

       通用mapper有什么好处呢?以往我们使用mapper文件都是自己写sql语句,针对的是单个实体,也就是每个实体都有其对应的mapper文件。使用通用mapper给我们带来了极大的方便,它不需要mapper.xml文件,只需我们调用相应的接口,引入jar包再进行简单的配置就好了。下面是使用中的一些总结。

首先我们要创建自己的接口来继承Mapper<T>,其中的T必须实现,也就是必须指定类型:

import com.github.abel533.mapper.Mapper;

@Repository("courseDao")

public interface CourseDao extends Mapper<Course>{}

这样我们就拥有了Mapper中的通用方法

如果是maven项目,在pom文件中添加如下依赖即可:

 

<!-- 通用Mapper -->

<dependency>

<groupId>com.github.abel533</groupId>

<artifactId>mapper</artifactId>

<version>2.3.4</version>

</dependency>

接下来就是修改mybatis配置文件,我们的配置文件都是通过spring来管理的,在网上查到一些资料,如果使用spring管理,直接在配置文件中按照如下配置即可:

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">

<property name="dataSource" ref="dataSource"/>

<property name="mapperLocations">

<array>

<value>classpath:mapper/*.xml</value>

</array>

</property>

<property name="typeAliasesPackage" value="com.dmsd.itoo.video.entity"/>

<property name="plugins">

<array>

<-- 主要看这里 -->

<bean class="com.isea533.mybatis.mapperhelper.MapperInterceptor"/>

</array>

</property>

</bean>

注意typeAliasesPackage的value对应的是你自己的实体的类名。

按照上述配置mybatis配置文件总是报如下错误:

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.builder.BuilderException: Error invoking SqlProvider method (com.github.abel533.mapper.MapperProvider.dynamicSQL). Cause: java.lang.InstantiationException: com.github.abel533.mapper.MapperProvider

查询无果,换另一种方式,将mybatis的配置文件单独抽出,在spring中进行引用,如下

spring-mybatis配置文件:

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">

<property name="dataSource" ref="dataSource" />

<property name="mapperLocations" value="classpath:mapper/*.xml" />

<property name="typeAliasesPackage" value="com.dmsd.itoo.video.entity" />

<!-- mybatis全局配置文件 -->

<property name="configLocation" value="classpath:spring/mybatis-config.xml" />

</bean>

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE configuration

PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

"http://mybatis.org/dtd/mybatis-3-config.dtd">

<configuration>

<plugins>

<!-- 通用Maper -->

<plugin interceptor="com.github.abel533.mapperhelper.MapperInterceptor">

<!-- 主键自增回写方法,默认值MYSQL,详细说明请看文档 -->

<property name="IDENTITY" value="MYSQL" />

<!-- 通用Mapper接口,多个通用接口用逗号隔开 -->

<property name="mappers" value="com.github.abel533.mapper.Mapper" />

</plugin>

</plugins>

 

</configuration>

运行,ok

 

注意

泛型(实体类)<T>的类型必须符合要求

实体类按照如下规则和数据库表进行转换,注解全部是JPA中的注解:

  1. 表名默认使用类名,驼峰转下划线,如UserInfo默认对应的表名为user_info.
  2. 表名可以使用@Table(name = "tableName")进行指定,对不符合第一条默认规则的可以通过这种方式指定表名.
  3. 字段默认和@Column一样,都会作为表字段,表字段默认为Java对象的Field名字驼峰转下划线形式.
  4. 可以使用@Column(name = "fieldName")指定不符合第3条规则的字段名
  5. 使用@Transient注解可以忽略字段,添加该注解的字段不会作为表字段使用.
  6. 建议一定是有一个@Id注解作为主键的字段,可以有多个@Id注解的字段作为联合主键.
  7. 默认情况下,实体类中如果不存在包含@Id注解的字段,所有的字段都会作为主键字段进行使用(这种效率极低).
  8. 实体类可以继承使用,可以参考测试代码中的com.github.abel533.model.UserLogin2类.
  9. 由于基本类型,如int作为实体类字段时会有默认值0,而且无法消除,所以实体类中建议不要使用基本类型.

除了上面提到的这些,Mapper还提供了序列(支持Oracle)、UUID(任意数据库,字段长度32)、主键自增(类似Mysql,Hsqldb)三种方式,其中序列和UUID可以配置多个,主键自增只能配置一个。

 

参考文章:http://blog.csdn.net/isea533/article/details/41457529

 

补充:

后来找到了通过spring管理mybatis的方法,不需要单独抽出mybatis的配置文件,修改spring-mybatis.xml如下:

[html] view plain copy

 
 

  1. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  2.         <property name="dataSource" ref="dataSource" />  
  3.         <property name="mapperLocations" value="classpath:mapper/*.xml" />  
  4.         <property name="typeAliasesPackage" value="com.dmsd.itoo.video.entity" />  
  5.         <property name="plugins">  
  6.             <array>  
  7.                 <bean class="com.github.abel533.mapperhelper.MapperInterceptor">  
  8.                     <property name="properties">  
  9.                         <value>  
  10.                             mappers=com.github.abel533.mapper.Mapper  
  11.                             IDENTITY=MYSQL  
  12.                             notEmpty=true  
  13.                         </value>  
  14.                     </property>  
  15.                 </bean>  
  16.             </array>  
  17.         </property>  
  18.         <!-- mybatis全局配置文件 -->  
  19.         <!-- <property name="configLocation" value="classpath:spring/mybatis-config.xml"></property> -->  
  20.     </bean>  

 

http://blog.csdn.net/xfz0330/article/details/52275192

 

时间: 2024-09-09 06:19:10

mybatis通用mapper的使用的相关文章

Mybatis 通用 Mapper 2.2.0 发布

Mybatis通用Mapper极其方便的使用Mybatis单表的增删改查 2.2.0 新增SqlMapper,可以使用MyBatis直接执行sql,详细文档 2.2.0版本之后,通过SqlMapper可以支持多表的操作,但是需要在代码中直接写SQL. 即使不使用通用mapper,相信SqlMapper也一定符合部分人的需求. 示例: selectList: //查询,返回List<Map> List<Map<String, Object>> list = sqlMapp

Spring Boot MyBatis 通用Mapper插件集成

看本文之前,请确保你已经在SpringBoot中集成MyBatis,并能正常使用. 如果没有,那么请先移步 http://blog.csdn.net/catoop/article/details/50553714 做了解后,再按本文步骤操作. 使用MyBatis在我们通过xml集中配置SQL,并通过创建接口Mapper文件来完成持久化DAO层(mybatis内部使用的是动态代理,所以我们不需要自己编写实现类). 然而在实际开发中,单表操作非常多,如果你也想像JPA.JDBC那样做一个所谓的Bas

Mybatis通用Mapper

极其方便的使用Mybatis单表的增删改查 项目地址:http://git.oschina.net/free/Mapper 优点? 不客气的说,使用这个通用Mapper甚至能改变你对Mybatis单表基础操作不方便的想法,使用它你能简单的使用单表的增删改查,包含动态的增删改查. 程序使用拦截器实现具体的执行Sql,完全使用原生的Mybatis进行操作. 你还在因为数据库表变动重新生成xml吗?还是要手动修改自动生成的insert|update|delete的xml呢?赶紧使用通用Mapper,表

Spring Boot MyBatis 通用Mapper插件集成 good

看本文之前,请确保你已经在SpringBoot中集成MyBatis,并能正常使用.如果没有,那么请先移步 http://blog.csdn.net/catoop/article/details/50553714 做了解后,再按本文步骤操作. 使用MyBatis在我们通过xml集中配置SQL,并通过创建接口Mapper文件来完成持久化DAO层(mybatis内部使用的是动态代理,所以我们不需要自己编写实现类). 然而在实际开发中,单表操作非常多,如果你也想像JPA.JDBC那样做一个所谓的Base

如何使用通用Mapper

集成方法请看上面的文档,集成后,可以继续阅读本页文档. 1. 继承通用的Mapper<T>,必须指定泛型<T> 例如下面的例子: public interface UserInfoMapper extends Mapper<UserInfo> { //其他必须手写的接口... } 一旦继承了Mapper<T>,继承的Mapper就拥有了Mapper<T>所有的通用方法.   2. 泛型(实体类)<T>的类型必须符合要求 实体类按照如下

mybatis3怎么实现通用mapper?

问题描述 项目在用mybatis3,按照以前的经验是可以将一些通用的CRUD封装成基础类的,但mybatis这种接口映射到SQL的方式,还没有找到是实现的方法,最近在javaeye上看到一个通用Mapper的实现,挺好,但是有个类MappedStatmentHelper的代码没有放出来,研究了半天也没能实现public static MappedStatement copyFromMappedStatement(MappedStatement ms, BoundSql newBoundSql)这

Mybatis提示Cannot find class [org.mybatis.spring.mapper.MapperScannerConfigurer]

问题描述 如题:mybatis提示如下异常,是什么原因?by: org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.mybatis.spring.mapper.MapperScannerConfigurer] for bean with name 'org.mybatis.spring.mapper.MapperScannerConfigurer#0' defined in

mybatis-generator生成通用mapper中文乱码解决

<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <

关于使用IntelliJ时myBatis的mapper.xml文件发布问题

问题描述 请教一下我正在使用IntelliJ开发一个数据库应用,用到了myBatis,生成的mapper.xml文件生成到了main/java/下面的某一个类路径中,当我部署和打包生成war文件的时候,在target目录中的对应目录中却没有找到mapper.xml文件,导致运行时错误.问题:我如何才能设置IntelliJ在部署和打包的时候让mapper文件自动的被复制到target目录中classes目录下对应的目录中呢?不好意思,初学使用IntelliJ,问的问题可能有点弱,还请有经验的朋友不