文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Mybatis实体类对象入参查询的方法

2023-07-02 11:18

关注

本篇内容介绍了“Mybatis实体类对象入参查询的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

Mybatis实体类对象入参查询

测试实体类对象结构如下

@Getter@Setter@NoArgsConstructor@ToString@EqualsAndHashCodepublic class Vendor {    private String vend_id;    private String vend_name;    private String vend_address;    private String vend_city;    private String vend_state;    private String vend_zip;    private String vend_country;}

XML映射文件

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="com.mybatis.mapper.VendorMapper">    <select id="findByVendorEntity" parameterType="vendor" resultType="vendor">      select * from Vendors where vend_id = #{vend_id} and vend_name = #{vend_name}  </select></mapper>

接口文件

public interface VendorMapper {    //通过Vendor对象查询    Vendors findByVendorEntity(Vendor vendor);}

测试文件内容

try {            String resource = "mybatis-config.xml";            InputStream resourceAsStream = Resources.getResourceAsStream(resource);            SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsStream,"development2");            //获取SQLSession            SqlSession openSession = build.openSession();                        VendorMapper mapper = openSession.getMapper(VendorMapper.class);            Vendor vendor = new Vendor();            vendor.setId("BRE02");            vendor.setName("Bear Emporium");                        Vendor findByVendorEntity = mapper.findByVendorEntity(vendor);            System.out.println(findByVendorEntity);        } catch (IOException e) {            System.out.println("加载配置文件失败");            e.printStackTrace();        }

笔记:

当对象作为参数传入查询时(不一定指定parameterType属性值为实体对象的别名或全路径名,typeHandler貌似会自动识别),SQL查询语句的#{}中内容需要与实体类的字段属性一一对应(并非实体类的属性一定是数据库表中的字段,只要填入的值对应即可。

mybatis查询条件是看sql语句的where后的查询条件),如果表达式中的值没有对应,则会报错。

错误示例如下:

....Cause:org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'ids' in 'class com.mybatis.beans.Vendors' ....Cause:org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'ids' in 'class com.mybatis.beans.Vendors'...

Mybatis中的参数深入

一、mybatis的参数

parameterType参数

该参数表示的是输入类型

1、传递简单类型

像int、string这种属于简单类型

2、传递pojo对象

pojo对象就是我们所说的JavaBean,mybatis使用ognl表达式解析对象字段的值,#{}或者${}括号中的值为pojo属性名称

什么是ognl表达式?

Mybatis实体类对象入参查询的方法

3、传递pojo包装对象

开发中通过实体类的包装对象(pojo包装对象)传递查询条件,查询条件是总和的查询条件,不仅宝库偶用户的查询条件,还包括其它的查询条件,这时候使用包装对象传递输入参数

举例说明,我们的QueryVo类中可以有多个对象,这里我们只存放一个user类

Mybatis实体类对象入参查询的方法

Mybatis实体类对象入参查询的方法

因为通过ognl表达式可以使用属性名打点调用的方式来将user中的username当作参数,同时也可以将别的类的属性当作参数传递进来

Mybatis实体类对象入参查询的方法

Mybatis实体类对象入参查询的方法

二、mybatis的输出结果的封装

resultType(输出类型)

mysql在windows系统下不区分列名的大小写,linux中严格区分大小写

Mybatis实体类对象入参查询的方法

当我们的实体类封装的时候,如果属性名和数据库中的列名,我们在使用mybatis查询的时候是查询不到的,那么我们如何解决这样的问题

Mybatis实体类对象入参查询的方法

我们只需要使封装的属性和表中的列名对应上就可以,

第一种解决方式:

查询数据库的时候起别名的方式

Mybatis实体类对象入参查询的方法

第二种解决方式,使用mybatis配置:

Mybatis实体类对象入参查询的方法

解释说明标签中的属性

“Mybatis实体类对象入参查询的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯