MyBatis3_[tp-26-27]_映射文件_select_返回List_记录封装Map:返回单个元素的Map或者整体Map集合
笔记要点
出错分析与总结
工程组织
1.定义接口
public interface EmployeeMapper {
//多条记录封装到一个map中: Map<Integer,Employee>,键是这条记录的主键,值时记录封装后的JavaBean
@MapKey("id") //告诉Mybatis 封装Map的时候,使用哪个属性作为map的key,当然要对应你的下一行的Integer
public Map<Integer,Employee> getEmpsByLastNameLikeRetMap( String lastName); //select 的返回值类型是Map ,返回一条记录的Map,key是列名,值就是对应的值;
public Map<String,Object> getEmpsByIdReturnMap(Integer id); //select 的返回值类型是List
public List<Employee> getEmpsByLastNameLike( String lastName); //多个参数处理,传入map
public Employee getEmpByMap(Map<String,Object> map);
}
2.定义XML映射文件 EmployeeMapper.xml
<?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="com.dao.EmployeeMapper"><!--namespace: 名称空间;id: 唯一标识; resultType:返回值类型; --> <!--public Map<Integer,Employee> getEmpsByLastNameLikeRetMap( String lastName);
如果返回的是一个集合,resultType要写Map中值 元素的类型:Employee
-->
<select id="getEmpsByLastNameLikeRetMap" resultType="com.bean.Employee" databaseId="mysql">
select * from tbl_employee
where last_name like #{lastName}
</select> <!--public Map<String,Object> getEmpsByIdReturnMap(Integer id);
记得更改,resultType="map"
-->
<select id="getEmpsByIdReturnMap" resultType="map" databaseId="mysql">
select * from tbl_employee
where id =#{id}
</select> <!--public List<Employee> getEmpsByLastNameLike( String lastName);
如果返回的是一个集合,resultType要写集合中元素的类型;
-->
<select id="getEmpsByLastNameLike" resultType="com.bean.Employee" databaseId="mysql">
select * from tbl_employee
where last_name like #{lastName}
</select> <!--public Employee getEmpByMap(Map<String,Object> map);-->
<select id="getEmpByMap" resultType="com.bean.Employee" databaseId="mysql">
select * from ${table_name}
where id = ${id} and last_name = #{lastName}
</select>
3.编写测试代码
public class test_tp26 {
public SqlSessionFactory getSqlSessionFactory() throws IOException {
String resource = "mybatis-config.xml";
InputStream inputStream=Resources.getResourceAsStream(resource);
return new SqlSessionFactoryBuilder().build(inputStream);
}
@Test
public void test06() throws Exception{
//默认是不自动提交数据的,需要我们自己手动提交
SqlSession openSession = getSqlSessionFactory().openSession();
try {
EmployeeMapper mapper = openSession.getMapper(EmployeeMapper.class); //1.select 返回List列表
List<Employee> like = mapper.getEmpsByLastNameLike("%e%");
for(Employee e:like){
System.out.println(e);
}
System.out.println("*********************"); //2.select 记录封装Map,返回单条记录
Map<String, Object> emps = mapper.getEmpsByIdReturnMap(1);
System.out.println(emps); //{gender=1, last_name=jerry, id=1, email=jerry@163.com}
System.out.println("*********************"); //3.select 记录封装Map,返回多组记录
Map<Integer, Employee> emps1 = mapper.getEmpsByLastNameLikeRetMap("%e%");
for(Map.Entry m: emps1.entrySet()){
System.out.println(m);
}
//{gender=1, last_name=jerry, id=1, email=jerry@163.com}
System.out.println("*********************"); //最后手动提交
openSession.commit();
}finally {
openSession.close();
}
}
}
测试结果
DEBUG 11-29 16:10:26,474 ==> Preparing: select * from tbl_employee where last_name like ? (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,493 ==> Parameters: %e%(String) (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,505 <== Total: 2 (BaseJdbcLogger.java:145)
Employee{id=1, lastname='jerry', email='jerry@163.com', gender='1'}
Employee{id=5, lastname='葫芦娃e', email='qwq@qq.com', gender='1'}
*********************
DEBUG 11-29 16:10:26,506 ==> Preparing: select * from tbl_employee where id =? (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,506 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,507 <== Total: 1 (BaseJdbcLogger.java:145)
{gender=1, last_name=jerry, id=1, email=jerry@163.com}
*********************
DEBUG 11-29 16:10:26,508 ==> Preparing: select * from tbl_employee where last_name like ? (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,508 ==> Parameters: %e%(String) (BaseJdbcLogger.java:145)
DEBUG 11-29 16:10:26,509 <== Total: 2 (BaseJdbcLogger.java:145)
1=Employee{id=1, lastname='jerry', email='jerry@163.com', gender='1'}
5=Employee{id=5, lastname='葫芦娃e', email='qwq@qq.com', gender='1'}
*********************
MyBatis3_[tp-26-27]_映射文件_select_返回List_记录封装Map:返回单个元素的Map或者整体Map集合的更多相关文章
- mybatis3.1-[topic-18-20]-_映射文件_参数处理_单个参数&多个参数&命名参数 _POJO&Map&TO 三种方式及举例
笔记要点出错分析与总结 /**MyBatis_映射文件_参数处理_单个参数&多个参数&命名参数 * _POJO&Map&TO 三种方式及举例 _ * 单个参数 : #{ ...
- Mybatis3.1-[tp_34-35]-_映射文件_select_resultMap关联查询_collection定义关联集合封装规则_collection分步查询_延迟加载
笔记要点出错分析与总结工程组织 1.定义接口 interface DepartmentMapper package com.dao; import com.bean.Department; publi ...
- Mybatis3.1-[tp_32-33]-_映射文件_select_resultMap关联查询_association分步查询_延迟加载
笔记要点出错分析与总结 工程组织 1.定义接口 DepartmentMapper package com.dao; import com.bean.Department; public interfa ...
- MyBatis 3.0_[tp-24-25]_映射文件_参数处理_#与$取值区别_#{}更丰富的用法
笔记要点出错分析与总结 /**================Mybatis参数值的获取:#和$符号的区别=============== * #{}:可以获得map中的值或者pojo对象属性的值; * ...
- Mybatis3.1-[tp_36-37]-_映射文件_select_resultMap关联查询__分步查询传递多列值&fetchType_discriminator鉴别器
_分步查询传递多列值&fetchType_discriminator鉴别器 笔记要点出错分析与总结 Department.java bean public class Department { ...
- 使用 hibernate 根据映射文件生成数据库表
为了更好的显示效果,可以在hibernate.cfg.xml配置文件的<session-factory>标签里加入以下内容: 显示sql语句和格式化显示sql语句: <propert ...
- .NET 4.0中使用内存映射文件实现进程通讯
操作系统很早就开始使用内存映射文件(Memory Mapped File)来作为进程间的共享存储区,这是一种非常高效的进程通讯手段.Win32 API中也包含有创建内存映射文件的函数,然而,这些函数都 ...
- Java-MyBatis-MyBatis3-XML映射文件:insert, update 和 delete
ylbtech-Java-MyBatis-MyBatis3-XML映射文件:insert, update 和 delete 1.返回顶部 1. insert, update 和 delete 数据变更 ...
- 第3章 文件I/O(7)_高级文件操作:存储映射
8. 高级文件操作:存储映射 (1)概念: 存储映射是一个磁盘文件与存储空间的一个缓存相映射,对缓存数据的读写就相应的完成了文件的读写. (2)mmap和munmap函数 头文件 #include&l ...
随机推荐
- clickHouse可视化查询工具
clickHouse以卓越的查询性能著称,目前在大数据的存储和分析领域有广泛应用,目前TreeSoft已支持clickHouse的数据在线查询分析,可以与Mysql,oracle等数据库并存操作. 1 ...
- WPF TextBlock 文本换行的两种方式
第一种: <TextBlock> This is line 1.<LineBreak/> This is line 2. </TextBlock> 第二种 < ...
- 任务调度之Quartz.Net可视化界面
上一篇关于任务调度Quartz.Net的文章中介绍了其三个核心对象IScheduler.IJob和ITrigger,我们已经知道了其基本的使用方法,可以在控制台当中运行监控.但是在实际中我们往往需要有 ...
- 学习Ajax小结
Ajax 学习 1.ajax的概念 局部刷新技术,不是一门新技术,是多种技术的组合,是浏览器端技术 2.作用 可以实现 ...
- linux c基础技巧
C语言:向文件末尾进行追加数据https://blog.csdn.net/qq_31243065/article/details/82354557 https://zhidao.baidu.com/q ...
- LeetCode 671. 二叉树中第二小的节点(Second Minimum Node In a Binary Tree) 9
671. 二叉树中第二小的节点 671. Second Minimum Node In a Binary Tree 题目描述 给定一个非空特殊的二叉树,每个节点都是正数,并且每个节点的子节点数量只能为 ...
- (转)基于FFPMEG2.0版本的ffplay代码分析
ref:http://zzhhui.blog.sohu.com/304810230.html 背景说明 FFmpeg是一个开源,免费,跨平台的视频和音频流方案,它提供了一套完整的录制.转换以及流化音视 ...
- MVC自定定义扩展点之ActionNameSelectorAttribute+ActionFilterAttribute 在浏览器中打开pdf文档
仅仅演示 了ASP.MVC 5 下为了在在浏览器中打开pdf文档的实现方式之一,借此理解下自定义ActionNameSelectorAttribute+ActionFilterAttribute 类的 ...
- windows + Eclipse 汉化
https://www.eclipse.org/babel/downloads.php 下载Eclipse 对应版本 汉化包解压 复制文件夹里的内容到eclipse 文件夹下对应的文件里 重启ecli ...
- 在我的电脑中删除wps云文档图标
在我的电脑中删除wps云文档图标 右键点击win10左下角选择运行,输入regedit打开注册表后,找到以下注册表路径: HKEY_CURRENT_USER\Software\Microsoft\Wi ...