4_MyBatis传统DAO模式开发-1_sqlSession查询的三种方式

普通模式,也称为传统DAO模式,就是在传统DAO模式下,定义接口和实现类,如 interface EmpDao  class EmpDaoImpl implements EmpDao.  在实现类中,用SQLSession对象调用select insert delete update 等方法实现.目前极为少见.在传统模式下,我们需要知道SqlSession对象 实现CURD和 参数传递的处理

1_sqlSession查询的三种方式

SqlSession对象本身的API中就有三个查询方法,分别能够实现如下查询方式

1返回单个对象 selectOne

2返回对象List集合 selectList

3返回对象Map集合 selectMap

接下来我们就对这三个方法进行一个快速的学习

创建Emp实体类

  • @AllArgsConstructor
  • @NoArgsConstructor
  • @Data
  • public class Emp implements Serializable {
  •     private Integer empno;
  •     private String ename;
  •     private String job;
  •     private Integer mgr;
  •     private Date hiredate;
  •     private Double sal;
  •     private Double comm;
  •     private Integer deptno;
  • }

准备Mapper映射文件

  • <?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="EmpMapper">
  •     <!--
  •     返回单个对象
  •     public Emp findOne();
  •     id 相当于方法名
  •     resultType 相当于返回值类型
  •         sql语句的查询结果用哪个类来进行封装 如果返回值类型是集合,这里写的也是集合中的元素对应的类,不是集合本身作为类型
  •     paramaterType 参数类型
  •     SQL语句就是具体的方法体的实现
  •     -->
  •     <select id="findOne" resultType="emp" >
  •         select * from emp where empno = 7499
  •     </select>
  •     <!--
  •     返回多个对象List集合
  •     查询全部的员工信息
  •     public List<Emp> findAll()
  •     -->
  •     <select id="findAll" resultType="emp">
  •         select * from emp
  •     </select>
  •     <!--返回多个对象的Map集合
  •     把查询出来的数据中的某一列作为键,整条数据封装的对象作为值
  •     public Map<key,Emp> findEmpMap()
  •     <empno,Emp>
  •     <key,Emp>
  •     -->
  •     <select id="findEmpMap" resultType="map">
  •         select * from emp
  •     </select>
  • </mapper>

sqlMapConfig中导入EmpMapper映射文件

  • <!--加载mapper映射文件-->
  • <mappers>
  •     <mapper resource="com/msb/mapper/DeptMapper.xml"/>
  •     <mapper resource="com/msb/mapper/EmpMapper.xml"/>
  • </mappers>

测试代码

  • package com.msb.test;
  • import com.msb.pojo.Dept;
  • import com.msb.pojo.Emp;
  • 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.IOException;
  • import java.io.InputStream;
  • import java.util.List;
  • import java.util.Map;
  • import java.util.Set;
  • /**
  • * @Author: Ma HaiYang
  • * @Description: MircoMessage:Mark_7001
  • */
  • public class Test2 {
  •     private SqlSession sqlSession;
  •     @Before
  •     public void init(){
  •         SqlSessionFactoryBuilder ssfb =new SqlSessionFactoryBuilder();
  •         InputStream resourceAsStream = null;
  •         try {
  •             resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
  •         } catch (IOException e) {
  •             e.printStackTrace();
  •         }
  •         SqlSessionFactory factory=ssfb.build(resourceAsStream) ;
  •         sqlSession=factory.openSession();
  •     }
  •     @Test
  •     public void testSelectOne(){
  •         // 查询单个对象
  •         System.out.println("sqlSession查询单个对象");
  •         Emp emp = sqlSession.selectOne("findOne");
  •         System.out.println(emp);
  •     }
  •     @Test
  •     public void testSelectList(){
  •         // 查询多个对象的List集合
  •         System.out.println("sqlSession查询对象List集合");
  •         List<Emp> emps = sqlSession.selectList("EmpMapper.findAll");
  •         emps.forEach(System.out::println);
  •     }
  •     @Test
  •     public void testSelectMap(){
  •         // 查询多个对象的Map集合
  •         System.out.println("sqlSession查询对象Map集合");
  •         Map<Integer, Emp> empMap = sqlSession.selectMap("findEmpMap", "EMPNO");
  •         Set<Integer> empnos = empMap.keySet();
  •         for (Integer empno : empnos) {
  •             System.out.println(empno+" :" +empMap.get(empno));
  •         }
  •     }
  •     @After
  •     public void release(){
  •         // 关闭SQLSession
  •         sqlSession.close();
  •     }
  • }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值