Springboot整合MyBatis参数传值的方法
本篇内容介绍了“Springboot整合MyBatis参数传值的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
成都创新互联公司主要从事成都网站设计、成都网站建设、网页设计、企业做网站、公司建网站等业务。立足成都服务宾阳,10余年网站建设经验,价格优惠、服务专业,欢迎来电咨询建站服务:028-86922220
环境:springboot2.3.9.RELEASE + MyBatis + MySQL
环境配置
依赖
org.springframework.boot spring-boot-starter-data-jpa mysql mysql-connector-java runtime org.mybatis.spring.boot mybatis-spring-boot-starter 2.1.4 com.github.pagehelper pagehelper-spring-boot-starter 1.3.0
应用配置
spring: datasource: driverClassName: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/testjpa?serverTimezone=GMT%2B8 username: root password: 123123 type: com.zaxxer.hikari.HikariDataSource hikari: minimumIdle: 10 maximumPoolSize: 200 autoCommit: true idleTimeout: 30000 poolName: MasterDatabookHikariCP maxLifetime: 1800000 connectionTimeout: 30000 connectionTestQuery: SELECT 1 --- spring: jpa: generateDdl: false hibernate: ddlAuto: update openInView: true show-sql: true --- pagehelper: helperDialect: mysql reasonable: true pageSizeZero: true offsetAsPageNum: true rowBoundsWithCount: true --- mybatis: type-aliases-package: com.pack.domain mapper-locations: - classpath:/mappers/*.xml
主要是数据源 + MyBatis starter + pagehelper相关配置。
Mapper接口参数传值方式
方式1:
ListqueryUsers1(String idNo, String username) ;
xml
根据方法的参数顺序param*。
或者:
直接写参数名称。
方式2:
通过@Param注解指明参数的名称
ListqueryUsers2(@Param("no")String idNo, @Param("un")String username) ;
xml
方式3:
通过Map传参
ListqueryUsers3(Map params) ;
xml
这里的#{xxx} 就是存入Map中的Key。
方式4:
通过对象传参
ListqueryUsers4(UsersDTO params) ;
UsersDTO.java
public class UsersDTO extends ParamsDTO { private String idNo ; private String username ; public String getIdNo() { return idNo; } public void setIdNo(String idNo) { this.idNo = idNo; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } }
xml
这里的#{xxx} 对象中必须有该属性对应的getter方法。
方式5:
List集合参数
ListqueryUsers5(Collection params) ;
xml
Mapper
@Mapper public interface UsersMapper { ListqueryUsers1(String idNo, String username) ; List queryUsers2(@Param("no")String idNo, @Param("un")String username) ; List queryUsers3(Map params) ; List queryUsers4(UsersDTO params) ; List queryUsers5(Collection params) ; }
XML
Controller
@Resource private UsersMapper usersMapper ; @GetMapping("/q1") public Object q1(UsersDTO params) { return R.success(Pager.query(params, () -> { return usersMapper.queryUsers1(params.getIdNo(), params.getUsername()) ; })) ; } @GetMapping("/q2") public Object q2(UsersDTO params) { return R.success(Pager.query(params, () -> { return usersMapper.queryUsers2(params.getIdNo(), params.getUsername()) ; })) ; } @GetMapping("/q3") public Object q3(UsersDTO params) { return R.success(Pager.query(params, () -> { Mapps = new HashMap<>() ; ps.put("id_no", params.getIdNo()) ; ps.put("user_name", params.getUsername()) ; return usersMapper.queryUsers3(ps) ; })) ; } @GetMapping("/q4") public Object q4(UsersDTO params) { return R.success(Pager.query(params, () -> { return usersMapper.queryUsers4(params) ; })) ; } @GetMapping("/q5") public Object q5(@RequestBody List ids) { return R.success(Pager.query(new UsersDTO(), () -> { return usersMapper.queryUsers5(ids) ; })) ; }
“Springboot整合MyBatis参数传值的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
文章标题:Springboot整合MyBatis参数传值的方法
文章地址:http://pcwzsj.com/article/ieoice.html