mybatis 同名方法_Mybatis框架----->(5) 深入理解Mybatis封装输出的结果和模糊查询like...

一、深入理解Mybatis封装输出的结果

1、resultType

指的是执行SQL语句得到ResultSet转换的类型,这里使用的转换类型可以为:

(1)全限定名称:com.hcz.entity.Student

(2)类型的别名:例如java.lang.Integer别名是int

(3)自定义别名:在mybatis主配置文件中定义,使用定义别名,然后可以在resultType中使用自定义别名

定义别名的两种方式如下:

第一种方式:

type:自定义类型的全限名称

alias:别名(短小,容易记忆)

第二种方式:

name是包名,这个包中的所有类,【类名】就是别名

注意: 如果返回的是集合,那也应该是集合包含的类型,而不是集合List本身。如下图:

b77772e0a4083657017aeedf01137596.png

执行原理:

1、mybatis执行sql语句, 然后mybatis调用类的无参数构造方法,创建对象。

2、mybatis调用set方法把ResultSet指定列值赋值给同名的属性。

映射文件:

select id,name, email,age from student

近似等价于以下jdbc代码:

ResultSet rs = executeQuery(" select id,name from student" )

while(rs.next()){

Student student = new Student();

student.setId(rs.getInt("id"));

student.setName(rs.getString("name"));

studentList.add(student);

}

这里sql执行后的列数据转为Java对象Student

c7a8c5e96070ddde31d5a6609d5e0fff.png

(1)简单类型

定义接口中的一个方法

int countStudent();

映射文件

select count(*) from student

定义测试方法

@Test

public void testRetunInt(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

int count = dao.countStudent();

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

}

(2)对象类型

定义接口中的一个方法

List selectMulitParam(@Param("myname") String name,

@Param("myage") Integer age);

映射文件

select * from student where name=#{myname} or age=#{myage}

定义测试方法

@Test

public void testSelectMulitParam(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

List studentList = dao.selectMulitParam("李四", 28);

for (Student student: studentList){

System.out.println("学生="+student);

}

}

(3)Map类型

返回值为map,其中列名(id,name,age)是map的key值,列值(1002,张三,34是map的value值)

其只能返回一行记录,不能返回多行记录

定义接口中的一个方法

Map selectReturnMap(int id);

映射文件

select * from student where id=#{sid}

定义测试方法

public void testReturnMap(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

Map retMap = dao.selectReturnMap(1002);

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

}

2、resultMap

resultMap是结果映射,指定列名和Java对象的属性对应关系,更灵活的把列值赋值给指定属性,常用在列名和Java对象属性名不一致的情况

使用方式:

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

(2)在中把resultType替换为resultMap

定义接口中的一个方法

List selectUseResultMap(QueryParam param);

映射文件

select * from student where name=#{paramName} or

age=#{paramAge}

解析:

(1)id:值为自定义的唯一名称,在< select >使用

(2)type:期望转为的Java对象的全限定名称或者别名

(3)column:数据库中的列名

(4)property:Java对象的属性名

(5)resultMap:< resultMap >的id值

定义测试方法

@Test

public void testSelectUseResultMap(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

QueryParam param = new QueryParam();

param.setParamName("李四");

param.setParamAge(28);

List stuList = dao.selectUseResultMap(param);

stuList.forEach( stu -> System.out.println(stu));

}

3、实体类属性名和列名不同的两种处理方式

(1)使用< resultMap >

定义接口中的一个方法

List selectMyStudent();

映射文件

select * from student

定义测试方法

@Test

public void testSelectMyStudent(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

List stuList = dao.selectMyStudent();

stuList.forEach( stu -> System.out.println("MyStudent="+stu));

}

(2)使用列别名和< resultType >

reultType的默认原则是:同名的列值赋值给同名的属性,这里使用列别名(Java对象的属性名)

定义接口中的一个方法

List selectDiffColProperty();

映射文件

select id as stuid,name as stuname,email as stuemail,age as stuage

from student

定义测试方法

@Test

public void testSelectDiffColProperty(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

List stuList = dao.selectDiffColProperty();

stuList.forEach( stu -> System.out.println("MyStudent="+stu));

}

注意:resultType和resultMap不能一起使用,只能二选一

二、模糊查询like

(1)在Java代码中给查询数据加上“%xxx%”(更方便)

定义接口中的一个方法

List selectLikeOne(String name);

映射文件

select id,name,email,age from student where name like #{name }

定义测试方法

@Test

public void testSelectLikeOne(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

//准备好like的内容

String name="%李%";

List stuList = dao.selectLikeOne(name);

stuList.forEach( stu -> System.out.println("OnelikeStudent="+stu));

}

(2)在映射文件中的SQL语句的条件位置加上“%” #{xxx} “%”

定义接口中的一个方法

List selectLikeTow(String name);

映射文件

select id,name,email,age from student where name like "%" #{name} "%"

定义测试方法

@Test

public void testSelectLikeTow(){

SqlSession sqlSession = MyBatisUtil.getSqlSession();

StudentDao dao = sqlSession.getMapper(StudentDao.class);

String name="李";

List stuList = dao.selectLikeTow(name);

stuList.forEach( stu -> System.out.println("TowlikeStudent="+stu));

}

三、思维大纲

727c077a9624038bee44208a4497bbc5.png

如有不足之处请大家指正哈!

转载自CSDN-专业IT技术社区

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值