zoukankan      html  css  js  c++  java
  • 使用Map接收返回数据库的数据

    查询返回值是map类型的一条数据

    1 首先在接口中写方法

    public interface EmployeeMapper {

    //返回一条记录的map;key就是列名,值就是对应的值
    public Map<String, Object> getEmpByIdReturnMap(Integer id);

    }

    2 在映射文件xml配置方法

    <!--public Map<String, Object> getEmpByIdReturnMap(Integer id); -->
    <select id="getEmpByIdReturnMap" resultType="map">
    select * from tbl_employee where id=#{id}
    </select>

    3在junit方法里进行测试

    @Test
    public void test04() throws IOException{

    SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
    //1、获取到的SqlSession不会自动提交数据
    SqlSession openSession = sqlSessionFactory.openSession();

    try{
    EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
    Map<String, Object> map = mapper.getEmpByIdReturnMap(1);
    System.out.println(map);
    String email=(String) map.get("email");
    System.out.println(email);
    }finally{
    openSession.close();
    }
    }

    查询返回值是map类型的多条数据

    1 首先在接口中写方法

    public interface EmployeeMapper {

    //多条记录封装一个map:Map<Integer,Employee>:键是这条记录的主键,值是记录封装后的javaBean
    //@MapKey:告诉mybatis封装这个map的时候使用哪个属性作为map的key

    @MapKey("email")
    public Map<String, Employee> getEmpByLastNameLikeReturnMap(String email);

    }

    2 在映射文件xml配置方法


    <!--public Map<Integer, Employee> getEmpByLastNameLikeReturnMap(String lastName); -->
    <select id="getEmpByLastNameLikeReturnMap" resultType="com.atguigu.mybatis.bean.Employee">
    select * from tbl_employee where email like #{email}
    </select>

    3在junit方法里进行测试

    @Test
    public void test04() throws IOException{

    SqlSessionFactory sqlSessionFactory = getSqlSessionFactory();
    //1、获取到的SqlSession不会自动提交数据
    SqlSession openSession = sqlSessionFactory.openSession();

    try{
    EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class);
    Map<String, Employee> map = mapper.getEmpByLastNameLikeReturnMap("%e%");
    System.out.println(map);
    System.out.println("第一条记录为:"+map.get("jerry6@atguigu.com"));
    System.out.println("第一条记录为:"+map.get("jerry6@atguigu.com").getEmail());

    }finally{
    openSession.close();
    }
    }

  • 相关阅读:
    超详细的 Vagrant 上手指南
    简单聊聊 Ironic
    什么是裸金属
    使用 minikube 快速上手 Kubernetes | v1.7.3
    来看看你对Python变量理解到位了没有
    python HelloWorld 的 4 种姿势,你知道几种
    Windows 系统安装 Python 3.8 详解
    myeclipse2017下载安装与破解详细教程
    eclipse中tomcat的add and Remove找不到项目
    cmd中查看MySQL数据库表数据及结构
  • 原文地址:https://www.cnblogs.com/zhangzhiqin/p/8545490.html
Copyright © 2011-2022 走看看