通用mapper的使用

本文详细介绍了MyBatis通用Mapper的使用,包括导入依赖、配置plugins、使用通用Mapper的注意事项,以及如何进行测试、解决密码隐藏问题、使用通用Example查询对象、改造userServiceImpl、处理部分乱码和复杂条件查询。在测试中,展示了如何插入、更新、查询数据,以及处理自增主键。同时,文章强调了使用`selective`更新时的注意事项和密码字段的处理方法。
摘要由CSDN通过智能技术生成

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值