通用mapper

1.  通用mapper的使用

1.1. 导入依赖

<dependency>

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

         <artifactId>mapper</artifactId>

         <version>2.3.4</version>

      </dependency>

 

1.2. 配置plugins

<plugininterceptor="com.github.abel533.mapperhelper.MapperInterceptor">

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

         <propertyname="IDENTITY"value="MYSQL"/>

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

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

      </plugin>

 

1.3. 新建mapper接口继承同样Mapper提供的接口

1.3.1.  继承通用的Mapper<T>,必须指定泛型<T>

1.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注解的字段作为联合主键.

1.4. 测试提供的方法

1.5. 通用的Example查询对象

1.5.1.  添加普通条件

 

 String bankCode= userDao.getBankCode(user.getLoginName());
  PageHelper.startPage(pageNum, pageSize);
  Example example = new Example(Product.class);
  // 排序
  example.setOrderByClause("lastUpdateDate desc");
  Example.Criteria criteria = example.createCriteria();
  //添加银行code
if(bankCode!=null && bankCode!=""){
      criteria.andEqualTo("bankCode",bankCode);
  }
  //end
  criteria.andEqualTo("sold",sold);
  criteria.andEqualTo("deleted","F");
  List<Product> products = productDao.selectByExample(example);
  PageInfo<Product> pageInfo = new PageInfo<Product>(products);
 

1.5.2.  添加or的查询条件

 

1.5.3.  添加排序功能

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值