前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >MyBatis-resultType参数

MyBatis-resultType参数

作者头像
星哥玩云
发布于 2022-09-14 13:20:39
发布于 2022-09-14 13:20:39
32700
代码可运行
举报
文章被收录于专栏:开源部署开源部署
运行总次数:0
代码可运行

1、resultType概述

resultType 属性可以指定结果集的类型,它支持基本类型和实体类类型。 需要注意的是,它和 parameterType 一样,如果注册过类型别名的,可以直接使用别名。没有注册过的必须使用全限定类名。

同时,当是实体类名称时,还有一个要求,实体类中的属性名称必须和查询语句中的列名保持一致,否则无法实现封装。

例如:我们的实体类此时必须是全限定类名(今天讲解如何配置实体类的别名)

2、需求分析

基本类型:查询数据库表(user)中的所有记录数的统计。

实体类型:查询数据库表(user)中的所有记录

3、案例回顾(基本类型)

3.1、编写IUserDao.java文件

代码语言:javascript
代码运行次数:0
运行
复制
package com.tianyi.dao;

public interface IUserDao {
    int allCount();
}

3.2、编写IUserDao.xml文件

代码语言:javascript
代码运行次数:0
运行
复制
<?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.tianyi.dao.IUserDao">
    <select id="allCount" resultType="int">
        select count(*) from user
    </select>
</mapper>

3.3、编写MbTest1.java文件

代码语言:javascript
代码运行次数:0
运行
复制
package com.tianyi.test;

        import com.tianyi.dao.IUserDao;
        import com.tianyi.javabean.QueryUser;
        import com.tianyi.javabean.User;
        import org.apache.ibatis.io.Resources;
        import org.apache.ibatis.session.SqlSession;
        import org.apache.ibatis.session.SqlSessionFactory;
        import org.apache.ibatis.session.SqlSessionFactoryBuilder;
        import org.junit.After;
        import org.junit.Before;
        import org.junit.Test;

        import java.io.InputStream;
        import java.util.Date;
        import java.util.List;

public class MbTest1 {
    private InputStream in ;
    private SqlSessionFactory factory;
    private SqlSession session;
    private IUserDao userDao;
    @Test
    public void allCount(){
        int n=userDao.allCount();
        System.out.println(n);
    }
    @Test
    public void findByUser(){
        QueryUser qu=new QueryUser();
        User u=new User();
        u.setUsername("%王%");
        qu.setUser(u);

        List<User> users=userDao.findByUser(qu);
        for(User user: users){
            System.out.println(user.getId()+":"+user.getUsername());
        }


    }
    @Before
    //在测试方法执行之前执行
    public void init()throws Exception {
        //1.读取配置文件
        in = Resources.getResourceAsStream("SqlMapConfig.xml");
        //2.创建构建者对象
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        //3.创建 SqlSession 工厂对象
        factory = builder.build(in);
        // 4.创建 SqlSession 对象
        session = factory.openSession();
        //5.创建 Dao 的代理对象
        userDao = session.getMapper(IUserDao.class);

    }

    @After//在测试方法执行完成之后执行
    public void destroy() throws Exception{
        session.commit();
        //7.释放资源
        session.close();
        in.close();
    }
}

4、案例回顾(实体类类型)

4.1、编写IUserDao.java文件

代码语言:javascript
代码运行次数:0
运行
复制
package com.tianyi.dao;

        import com.tianyi.javabean.QueryUser;
        import com.tianyi.javabean.User;

        import java.util.List;

public interface IUserDao {
    List<User> findAll();
}

4.2、编写IUserDao.xml文件

代码语言:javascript
代码运行次数:0
运行
复制
<?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.tianyi.dao.IUserDao">
<!-- 配置查询所有操作 -->
    <select id="findAll" resultType="com.tianyi.javabean.User">
        select * from user
    </select>
</mapper>

4.3、编写MbTest1.java文件

代码语言:javascript
代码运行次数:0
运行
复制
package com.tianyi.test;

        import com.tianyi.dao.IUserDao;
        import com.tianyi.javabean.QueryUser;
        import com.tianyi.javabean.User;
        import org.apache.ibatis.io.Resources;
        import org.apache.ibatis.session.SqlSession;
        import org.apache.ibatis.session.SqlSessionFactory;
        import org.apache.ibatis.session.SqlSessionFactoryBuilder;
        import org.junit.After;
        import org.junit.Before;
        import org.junit.Test;

        import java.io.InputStream;
        import java.util.Date;
        import java.util.List;

public class MbTest1 {
    private InputStream in ;
    private SqlSessionFactory factory;
    private SqlSession session;
    private IUserDao userDao;
    
    @Test
    public void findAll(){  
        List<User> users=userDao.findAll();
        for(User user: users){
            System.out.println(user.getId()+":"+user.getUsername());
        }
    }
    @Before
    //在测试方法执行之前执行
    public void init()throws Exception {
        //1.读取配置文件
        in = Resources.getResourceAsStream("SqlMapConfig.xml");
        //2.创建构建者对象
        SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
        //3.创建 SqlSession 工厂对象
        factory = builder.build(in);
        // 4.创建 SqlSession 对象
        session = factory.openSession();
        //5.创建 Dao 的代理对象
        userDao = session.getMapper(IUserDao.class);

    }

    @After//在测试方法执行完成之后执行
    public void destroy() throws Exception{
        session.commit();
        //7.释放资源
        session.close();
        in.close();
    }
}

5、返回对象属性与表字段不匹配

5.1、重写User.java文件

代码语言:javascript
代码运行次数:0
运行
复制
package com.tianyi.javabean;

import java.io.Serializable;
import java.util.Date;

public class User implements Serializable {
    private Integer uid;
    private String uname;
    private Date ubirthday;
    private String Sex;
    private String uaddress;

    public Integer getUid() {
        return uid;
    }

    public void setUid(Integer uid) {
        this.uid = uid;
    }

    public String getUname() {
        return uname;
    }

    public void setUname(String uname) {
        this.uname = uname;
    }

    public Date getUbirthday() {
        return ubirthday;
    }

    public void setUbirthday(Date ubirthday) {
        this.ubirthday = ubirthday;
    }

    public String getSex() {
        return Sex;
    }

    public void setSex(String sex) {
        Sex = sex;
    }

    public String getUaddress() {
        return uaddress;
    }

    public void setUaddress(String uaddress) {
        this.uaddress = uaddress;
    }

    @Override
    public String toString() {
        return "User{" +
                "uid=" + uid +
                ", uname='" + uname + '\'' +
                ", ubirthday=" + ubirthday +
                ", Sex='" + Sex + '\'' +
                ", uaddress='" + uaddress + '\'' +
                '}';
    }
}

5.2、修改IUserDao.xml文件

代码语言:javascript
代码运行次数:0
运行
复制
<?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.tianyi.dao.IUserDao">
<!-- 配置查询所有操作 -->
    <select id="findAll" resultType="com.tianyi.javabean.User">
        select id as uid,username as uname, birthday as ubirthday,sex as Sex,address as uaddress from user
    </select>
</mapper>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
MyBatis-parameterType参数
使用标签的 parameterType 属性来设定。该属性的取值可以是基本类型,引用类型(例如:String 类型),还可以是实体类类型(POJO 类)。同时也可以使用实体类的包装类,下面我们来介绍如何使用实体类的包装类作为参数传递。
星哥玩云
2022/09/14
3650
MyBatis-parameterType参数
MyBatis工作原理
前面我们学习了MyBatis的一些简单案例实现,下面我们来了解一下MyBatis工作原理。
星哥玩云
2022/09/14
6920
MyBatis工作原理
MyBatis-动态SQL
Mybatis 的映射文件中,前面我们的 SQL 都是比较简单的,有些时候业务逻辑复杂时,我们的 SQL 是动态变化的。
星哥玩云
2022/09/14
6480
MyBatis持久层的传统开发
1、MyBatis持久层的传统开发-上 1.1、创建项目 **GroupId:**com.tianyi **ArtifactId:**mb004 **Version:**1.0-SNAPSHOT 1.
星哥玩云
2022/09/14
3050
MyBatis-resultMap参数
resultMap 标签可以建立查询的字段名和实体类的属性名称不一致时建立对应关系。从而实现封装。 在 select 标签中使用 resultMap 属性指定引用即可。同时 resultMap 可以实现将查询结果映射为复杂类型的 pojo,比如在查询结果映射对象中包括 pojo 和 list 实现一对一查询和一对多查询。
星哥玩云
2022/09/14
3790
MyBatis入门
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis 。2013年11月迁移到Github。
星哥玩云
2022/09/14
3250
MyBatis入门
MyBatis基于DAO实现CRUD
resultType 属性: 用于指定结果集的类型。 **parameterType 属性:**用于指定传入参数的类型。
星哥玩云
2022/09/14
8140
MyBatis CRUD详解
*该案例中演示了以下的操作 1. 查询所有 2. 保存用户 3. 更新用户 4. 删除用户 5. 根据id查询用户 6. 根据名称模糊查询 7. 获取用户的总记录条数 8. 根据queryVo的条件查询用户 9. 获取用户的前几条数据 10. 根据多条件查询 11. 根据QueryVo中的Id集合查询用户列表
不愿意做鱼的小鲸鱼
2022/09/24
4150
MyBatis CRUD详解
MyBatis多表查询详解
MyBatis多表查询 0. 分析 一对一 一个用户只能拥有一个一个账户 sql语句: select u.*,a.id as aid,a.uid,a.money from account a,user u where a.uid =u.id; 一对多 一个用户可以拥有多个账户 sql语句 select u.*,a.id as aid ,a.uid,a.money from user u left outer join account a on u.id =a.uid 多对多
不愿意做鱼的小鲸鱼
2022/09/24
9820
MyBatis多表查询详解
快速学习-Mybatis框架入门
通过前面的学习,我们已经能够使用所学的基础知识构建自定义的 Mybatis 框架了。这个过程是基本功的考验,我们已经强大了不少,但现实是残酷的,我们所定义的 Mybatis 框架和真正的 Mybatis 框架相比,还是显得渺小。行业内所流行的 Mybatis 框架现在我们将开启学习。
cwl_java
2020/04/01
3690
Mybatis框架入门
框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种 定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。
暴躁的程序猿
2022/03/23
1900
快速学习-Mybatis 传统DAO 层开发
第5章 Mybatis 传统DAO 层开发[了解] 使用 Mybatis 开发 Dao,通常有两个方法,即原始 Dao 开发方式和 Mapper 接口代理开发方式。而现在主流的开发方式是接口代理开发方式,这种方式总体上更加简便。我们的课程讲解也主要以接口代理开发方式为主。在第二章节已经给大家介绍了基于代理方式的 dao 开发,现在给大家介绍一下基于传统编写 Dao 实现类的开发方式。 5.1 Mybatis 实现 DAO 的传统开发方式 5.1.1 持久层 Dao 接口 public interfac
cwl_java
2020/04/02
5310
F003MyBatis学习笔记-MyBatis增删改查及深入
(Java Bean(实体类对象),Mybatis使用ognl表达式解析对象字段的值,#{}或者${}括号中的值为pojo属性名称)
訾博ZiBo
2025/01/06
1060
F003MyBatis学习笔记-MyBatis增删改查及深入
(一)Mybatis的入门 - Titan的Mybatis系列学习笔记
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Ordinary Java Object,普通的 Java对象)映射成数据库中的记录。
泰坦HW
2020/07/22
5200
(一)Mybatis的入门 - Titan的Mybatis系列学习笔记
MyBatis注解开发
指的是MyBatis中SqlSession对象的缓存,当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。
用户3112896
2019/09/26
4880
【Mybatis 入门指北】2、Mybatis 入门实例及 CRUD
上一篇文章中我们讲了什么是持久化以及 Mybatis 的相关简介,今天就来看看如何创建一个 Mybatis 入门实例以及如何利用 Mybatis 进行 CRUD。
村雨遥
2022/06/16
3570
【Mybatis 入门指北】2、Mybatis 入门实例及 CRUD
快速学习Mybatis-Mybatis框架快速入门
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
cwl_java
2019/12/11
4450
Mybatis的多表关联查询(多对多)「建议收藏」
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/132932.html原文链接:https://javaforall.cn
全栈程序员站长
2022/08/14
1.8K0
Mybatis的多表关联查询(多对多)「建议收藏」
超简单入门MyBatis
3,我们写映射接口;类的具体实现方法,都写在映射接口里面;俗称Mapp ers,也可以叫dao层;
程序员的时光001
2020/07/14
3580
MyBatis编写Dao实现类
1、创建实现类 恢复我们的IUserDao.xml文件 UserDaoImpl.java package com.tianyi.dao.impl; import com.tianyi.dao.IUserDao; import com.tianyi.javabean.User; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import java.util.L
星哥玩云
2022/09/14
3010
相关推荐
MyBatis-parameterType参数
更多 >
目录
  • 1、resultType概述
  • 2、需求分析
  • 3、案例回顾(基本类型)
    • 3.1、编写IUserDao.java文件
    • 3.2、编写IUserDao.xml文件
    • 3.3、编写MbTest1.java文件
  • 4、案例回顾(实体类类型)
    • 4.1、编写IUserDao.java文件
    • 4.2、编写IUserDao.xml文件
    • 4.3、编写MbTest1.java文件
  • 5、返回对象属性与表字段不匹配
    • 5.1、重写User.java文件
    • 5.2、修改IUserDao.xml文件
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档