1.导入依赖
Pom.xml中的配置:
<dependency> <groupId>com.github.abel533</groupId> <artifactId>mapper</artifactId> <version>2.3.4</version> </dependency> |
2.配置plugins
Mybatis-config.xml的plugins下新增plugin配置。注意:该插件必须配置在分页插件下方,目前没有分页插件,暂不用理会
<plugin interceptor="com.github.abel533.mapperhelper.MapperInterceptor"> <!--主键自增回写方法,默认值MYSQL,详细说明请看文档 --> <property name="IDENTITY" value="MYSQL" /> <!--通用Mapper接口,多个通用接口用逗号隔开 --> <property name="mappers" value="com.github.abel533.mapper.Mapper" /> </plugin> |
3.使用通用mapper
3.1继承通用的Mapper<T>,必须指定泛型<T>
3.2泛型(实体类)<T>的类型必须符合要求
1、表名默认使用类名,驼峰转下划线(只对大写字母进行处理),如UserInfo默认对应的表名为user_info。
2、表名可以使用@Table(name = "tableName")进行指定,对不符合第一条默认规则的可以通过这种方式指定表名.
3、字段默认和@Column一样,都会作为表字段,表字段默认为Java对象的Field名字驼峰转下划线形式.
4、可以使用@Column(name = "fieldName")指定不符合第3条规则的字段名
5、使用@Transient注解可以忽略字段,添加该注解的字段不会作为表字段使用.
6、建议一定是有一个@Id注解作为主键的字段,可以有多个@Id注解的字段作为联合主键.
获取自增主键:
//不限于@Id注解的字段,但是一个实体类中只能存在一个(继承关系中也只能存在一个)
@GeneratedValue(generator = "JDBC")
private Integer id;
这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系数据库管理系统的自动递增字段)。
4测试通用方法
:::如果POJO类名和表名不对应一定要在类名上指名对应的表名
( 数据库表名为tab_user,而实体类名为user ) 如下 :
4.1新建测试类
public class NewUserMapperTest {
private NewUserMapper userMapper;
@Before
public void setUp() throws Exception {
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(new String[]{ "spring/applicationContext.xml", "spring/applicationContext-mybatis.xml", "spring/applicationContext-transaction.xml",});
userMapper = applicationContext.getBean(NewUserMapper.class);
}
@Test
public void testSelectOne() {
User user = new User();
user.setUid(48);
System.out.println(userMapper.selectOne(user