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

MyBatis的学习(四):封装Mybatis的输出结果

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

MyBatis的学习(四):封装Mybatis的输出结果

MyBatis的学习(四):封装Mybatis的输出结果

目录

MyBatis的学习(四):封装Mybatis的输出结果

resultType的使用

简单类型/定义别名返回Map resultMap的使用

解决列名和属性名不一样的第二种方法 模糊查询Like

第一种方法模糊查询第二种方法模糊查询

resultType的使用

执行sql语句之后得到的ResultSet转换的类型,使用类名的全限定名称或者别名。

注意:如果返回的是集合,那么应该设置为集合的类型,而不是集合的本身。resultType和resultMap不能同时使用。

    mybatis执行语句,然后调用类的无参构造,创建对象。mybatis把ResultSet指定列值赋值给同名的属性。

举个例子:

    编写一个返回类,注意属性名称要和数据库的列名保持一致,不然无法赋值。
package com.liang.vo;


public class ViewStudent {

    private Integer id;
    private String name;

    public ViewStudent() {
    }

    public ViewStudent(Integer id, String name) {
        this.id = id;
        this.name = name;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "ViewStudent{" +
                "id=" + id +
                ", name='" + name + ''' +
                '}';
    }
}
    剩下的按步骤填写
    
    public ViewStudent selectViewStudent(@Param("myname") String name);

        select COUNT(*) from student;
    

测试方法

@Test
public void testselectcountStudent(){
    //获取SqlSession对象
    SqlSession sqlSession = MybatisUtils.getSqlSession();
    //动态代理获取dao的实体类
    StudentDao dao = sqlSession.getMapper(StudentDao.class);
    //执行语句
    int count = dao.countStudent();
    //输出结果
    System.out.println("学生的数量:"+count);
    sqlSession.close();
}

定义自定义类型的别名(不建议使用别名,如果必须要用,那实际应用中建议使用第二种)

    方法一:需要在mybatis的主配置文件的配置typeAliases下的typeAlias。
    
    
        
        
    
    需要在mybatis的主配置文件的配置typeAliases下的typeAlias。
    
    
    
        
        
        
    
返回Map

列名是map的key,列值就是map的value只能最多返回一行记录,多余一行都是错误的,不推荐使用

    定义dao接口
    
    Map selectMapById(Integer id);
    mapper文件
    
    
        select id,name,email,age from student
    
    编写测试方法
    @Test
    public void testSelectAllStu(){
        //获取SqlSession对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //动态代理获取dao的实体类
        StudentDao dao = sqlSession.getMapper(StudentDao.class);
        //执行语句
        List students = dao.selectAllStu();
        //输出结果
        for (Student stu:students) {
            System.out.println("查询到的学生是:"+stu);
        }
        sqlSession.close();
    }
    测试结果

解决列名和属性名不一样的第二种方法
    dao接口
    
    List selectMyStu();
    map文件
    
    
        select id,name,email,age from student where name like #{name}
    
    测试方法
    @Test
    public void testSelectListStu(){
        //获取SqlSession对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //动态代理获取dao的实体类
        StudentDao dao = sqlSession.getMapper(StudentDao.class);
        //执行语句
        //准备号like的内容
        String name = "%赵%";
        List students = dao.selectListStu(name);
        //输出结果
        for (Student stu:students) {
            System.out.println("查询的学生是:"+stu);
        }
        sqlSession.close();
    }
    测试结果

第二种方法模糊查询
    dao接口
    
    List selectLikeStu(String name);
    mapper文件
    
    
    测试方法
    @Test
    public void testSelectLikeStu(){
        //获取SqlSession对象
        SqlSession sqlSession = MybatisUtils.getSqlSession();
        //动态代理获取dao的实体类
        StudentDao dao = sqlSession.getMapper(StudentDao.class);
        //执行语句
        //准备号like的内容
        List students = dao.selectLikeStu("赵");
        //输出结果
        for (Student stu:students) {
            System.out.println("查询的学生是:"+stu);
        }
        sqlSession.close();
    }
    测试结果

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

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

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