写点什么

IDEA 这样配置,好用到爆炸!,金九银十怎么从中小企业挤进一线大厂

用户头像
极客good
关注
发布于: 刚刚


resultType: 执行 sql 得到 ResultSet 转换的类型,使用类型的完全限定名或别名。 注意如果返回的是集合,那应该设置为集合包含的类型,而不是集合本身。resultType??和 resu?ltMap,不能同时使用。


A、 简单类型

接口方法:


int countStudent();


mapper 文件:


< select id="countStudent"?


resultType="int">?select count(*) from?


student


< /select>


复制代码


测试方法:


@Test


public void testRetunInt(){


int count = studentDao.countStudent();?


System.out.println("学生总人数:"+ count);


}


复制代码

B、对象类型

接口方法:


Student selectById(int id);


mapper 文件:


<select id="selectById"?


resultType="com.bjpowernode.domain.Student">?select?


id,name,email,age from student where id=#{studentId}


</select>


复制代码


框架的处理: 使用构造方法创建对象。调用 setXXX 给属性赋值。


Student student = new Student();



注意:Dao 接口方法返回是集合类型,需要指定集合中的类型,不是集合本身。


C、Map

sql 的查询结果作为 Map 的 key 和 value。推荐使用 Map<Object,Object>。


注意:Map 作为接口返回值,sql 语句的查询结果最多只能有一条记录。大于一条记录是错误。


接口方法:


Map<Object,Object> selectReturnMap(int id);


mapper 文件:


<select id="selectReturnMap" resultType="java.util.HashMap">?


select name,email from student where id = #{studentId}


</select>


复制代码


测试方法:


@Test


public void testReturnMap(){


Map<Object,Object> retMap = studentDao.selectReturnMap(1002);? ?


System.out.println("查询结果是 Map:"+retMap);


}


复制代码


resultMap




resultMap 可以自定义 sql 的结果和 java 对象属性的映射关系。更灵活的把列值赋值给指定属性。


常用在列名和 java 对象属性名不一样的情况。


使用方式:


1.先定义 resultMap,指定列名和属性的对应关系。


2.在< select>中把 resultType 替换为 resultMap。


接口方法:


List< Student> selectUseResultMap(QueryParam param);


mapper 文件:



测试方法:


实体类属性名和列名不同的处理方式

(1)?使用列别名和< resultType>


步骤:


**1.?创建新的实体类 PrimaryStuden


【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
复制代码


t**



2.?接口方法


List< PrimaryStudent> selectUseFieldAlias(QueryParam param);


3.?mapper?文件:



4.?测试方法



(2)?使用< resultMap>


步骤:

用户头像

极客good

关注

还未添加个人签名 2021.03.18 加入

还未添加个人简介

评论

发布
暂无评论
IDEA这样配置,好用到爆炸!,金九银十怎么从中小企业挤进一线大厂