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();
    }
    }

  • 相关阅读:
    高等软工第三次作业——设计也可以按图索骥
    高等软工第二次作业-从需求分析看软件开发的挑战
    高等软工第一次作业——期望与笃信
    【ACM-ICPC 2018 徐州赛区网络预赛】D.Easy Math 杜教筛
    【HDU 6428】Calculate 莫比乌斯反演+线性筛
    【BZOJ 4199】[Noi2015]品酒大会 后缀自动机+DP
    【BZOJ 3238】差异 后缀自动机+树形DP
    【Codeforces Round #466】E. Cashback DP+ST表
    【BZOJ 4709】柠檬 斜率优化dp+单调栈
    Hello Tornado
  • 原文地址:https://www.cnblogs.com/zhangzhiqin/p/8545490.html
Copyright © 2011-2022 走看看