栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

详解mybatis中association和collection的column传入多个参数问题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

详解mybatis中association和collection的column传入多个参数问题

项目中在使用association和collection实现一对一和一对多关系时需要对关系中结果集进行筛选,如果使用懒加载模式,即联合使用select标签时,主sql和关系映射里的sql是分开的,查询参数传递成为问题。

mybatis文档:

property description
column 数据库的列名或者列标签别名。与传递给resultSet.getString(columnName)的参数名称相同。注意: 在处理组合键时,您可以使用column=“{prop1=col1,prop2=col2}”这样的语法,设置多个列名传入到嵌套查询语句。这就会把prop1和prop2设置到目标嵌套选择语句的参数对象中。


 
 



 
 
  
  
 



 SELECT
  ci.city,
  ads.address,
  ads.district
 FROM
  (
   SELECt
    city,
    city_id
   FROM
    city ci
   WHERe
    ci.city_id = #{cityId}
  ) ci
 LEFT JOIN address ads ON ads.city_id = ci.city_id
 
  
   and ads.address RegExp #{adr}
  
  
   ads.district Regexp #{dis}
  
 

测试文件:

@Test
public void findCountryCityAddressTest() throws JsonProcessingException {
 Map param = new HashMap<>();
 param.put("addressQuery","1168");
 List> rs = countryManager.findCountryCityAddress(param);
 ObjectMapper mapper = new ObjectMapper();
 ObjectWriter writer = mapper.writerWithDefaultPrettyPrinter();
 System.out.println(writer.writevalueAsString(rs));
}

测试结果:

[
 {
  "country": "Afghanistan",
  "cityList": [{
    "city": "Kabul",
    "addressList": [{
      "address": "1168 Najafabad Parkway",
      "district": "Kabol"
     }
    ]
   }
  ],
  "city_id": 251
 },
 {
  "country": "Algeria",
  "cityList": [],
  "city_id": 59
 }
]

可以看到,确实将查询条件通过column参数传入到第二个sql中,并执行成功

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/136813.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号