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

  • 相关阅读:
    “小咖秀”火爆的背后,给我们开发者带来的思考
    移动互联网时代,好程序员的标准是什么?
    Android Studio之gradle的配置与介绍
    Android新组件RecyclerView介绍,其效率更好
    常见面试第二题之什么是Context
    常见面试题之ListView的复用及如何优化
    Ext学习之——活用Grid表格和TabPanel页切
    Ext学习之——实现Combo的本地模糊搜索(支持拼音)
    ExtJS学习之——实现Store数据过滤filterBy
    软件工程实训总结
  • 原文地址:https://www.cnblogs.com/zhangzhiqin/p/8545490.html
Copyright © 2020-2023  润新知