广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis之@ResultMap,@Results,@Result注解的使用
  • 926
分享到

Mybatis之@ResultMap,@Results,@Result注解的使用

2024-04-02 19:04:59 926人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录mybatis注解@Results、@Result、@ResultMap问题方法一方法二mybatis注释使用resultMap对应的注释,及对应注解Results、Result

Mybatis注解@Results、@Result、@ResultMap

问题

在使用mybatis时发现,mybatis能自动匹配实体名和数据库字段名相同的字段。当有实体名与数据库的字段名不同时该如何解决??

数据库的表对应的列名:

在这里插入图片描述

SpringBoot项目中建的实体类为:


public class MapModel {
    private Long key;
    private String value;
    
    //省略getter、setter方法
    }

方法一

给查询字段另起名对应实体类的名称:


@Select("SELECT province_id as key , province_name as value FROM `j_position`")
public List<MapModel> provinceName();

方法二

使用@Results、@Result、@ResultMap注解:


@Select("SELECT province_id, province_name FROM `j_position`")
    @Results(id="resultMap1" ,value = {
            @Result(property = "key",column = "province_id"),
            @Result(property = "value",column ="province_name")
    })
public List<MapModel> provinceName();

其中定义的id="resultMap1"可以使用


@ResultMap("resultMap1)
@Select("SELECT province_id, province_name FROM `j_position` where province_name=#{name}")
public List<MapModel> provinceName(String name);

推荐使用方法二!

mybatis注释使用

resultMap对应的注释,及对应注解Results、Result、One、Many的使用

有一部分建立在我上一个博客,mybatis注释使用(单表查询),如果那里看不懂了,建议看下我上一个博客(里面所有的配置文件,接口,数据库的创建都有说明)

<resultMap>对应的注解:

1.@Results注解

代替的是标签<resultMap >

该注解中可以使用单个@Result注解,也可以使用@Result集合


@Results({@Result(),@Result()})或@Results(@Result())

注意:使用注解是若报出org.apache.ibatis.binding.BindingException:Invalid bound statement (not found):接口全类名.方法名

可能是使用@Results注解时忘记使用@Select注解

2.@Resutl注解

代替了 <id>标签和<result>标签

@Result 中 属性介绍:

  • column 数据库的列名
  • Property需要装配的属性名
  • one 需要使用的@One注解(@Result(one=@One)()))
  • many 需要使用的@Many注解(@Result(many=@many)()))

3.@One注解(一对一)

代替了<assocation>标签,是多表查询的关键,在注解中用来指定子查询返回单一对象。

@One注解属性介绍:

  • select 指定用来多表查询的sqlmapper
  • fetchType会覆盖全局的配置参数lazyLoadingEnabled。。

使用格式:


@Result(column=" ",property="",one=@One(select=""))

4.@Many注解(多对一)

代替了<Collection>标签,是是多表查询的关键,在注解中用来指定子查询返回对象集合。

注意:聚集元素用来处理“一对多”的关系。需要指定映射的Java实体类的属性,属性的javaType(一般为ArrayList)但是注解中可以不定义;

使用格式:


@Result(property="",column="",many=@Many(select=""))

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Mybatis之@ResultMap,@Results,@Result注解的使用

本文链接: https://www.lsjlt.com/news/158937.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作