一、深入理解Mybatis封裝輸出的結果
1、resultType
- 指的是執行SQL陳述句得到ResultSet轉換的型別,這里使用的轉換型別可以為:
(1)全限定名稱:com.hcz.entity.Student
(2)型別的別名:例如java.lang.Integer別名是int
(3)自定義別名:在mybatis主組態檔中定義,使用<typeAlias>定義別名,然后可以在resultType中使用自定義別名
定義別名的兩種方式如下:
-
第一種方式:
-
type:自定義型別的全限名稱
-
alias:別名(短小,容易記憶)
<typeAlias type="com.hcz.entity.Student" alias="stu"/>
<typeAlias type="com.hcz.vo.ViewStudent" alias="vstu"/>
- 第二種方式:
- <package> name是包名,這個包中的所有類,【類名】就是別名
<package name="com.hcz.entity"/>
<package name="com.hcz.vo"/>
注意: 如果回傳的是集合,那也應該是集合包含的型別,而不是集合List本身,如下圖:

執行原理:
1、mybatis執行sql陳述句, 然后mybatis呼叫類的無引數構造方法,創建物件,
2、mybatis呼叫set方法把ResultSet指定列值賦值給同名的屬性,
映射檔案:
<select id="selectMultiPosition" resultType="com.bjpowernode.domain.Student">
select id,name, email,age from student
</select>
近似等價于以下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
(1)簡單型別
- 定義介面中的一個方法
int countStudent();
- 映射檔案
<!--回傳int型別數值-->
<select id="countStudent" resultType="int">
select count(*) from student
</select>
- 定義測驗方法
@Test
public void testRetunInt(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
int count = dao.countStudent();
System.out.println("學生總人數:"+ count);
}
(2)物件型別
- 定義介面中的一個方法
List<Student> selectMulitParam(@Param("myname") String name,
@Param("myage") Integer age);
- 映射檔案
<select id="selectMulitParam" resultType="Student">
select * from student where name=#{myname} or age=#{myage}
</select>
- 定義測驗方法
@Test
public void testSelectMulitParam(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
List<Student> 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<Object,Object> selectReturnMap(int id);
- 映射檔案
<select id="selectReturnMap" resultType="java.util.HashMap">
select * from student where id=#{sid}
</select>
- 定義測驗方法
public void testReturnMap(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
Map<Object,Object> retMap = dao.selectReturnMap(1002);
System.out.println("查詢結果是 Map:"+retMap);
}
2、resultMap
- resultMap是結果映射,指定列名和Java物件的屬性對應關系,更靈活的把列值賦值給指定屬性,常用在列名和Java物件屬性名不一致的情況
使用方式:
(1)先定義resultMap,指定列名和屬性的對應關系
(2)在<select>中把resultType替換為resultMap
- 定義介面中的一個方法
List<Student> selectUseResultMap(QueryParam param);
- 映射檔案
<resultMap id="studentMap" type="Student">
<!-- 主鍵欄位使用 id -->
<id column="id" property="id" />
<!--非主鍵欄位使用 result-->
<result column="name" property="name"/>
<result column="email" property="email" />
<result column="age" property="age" />
</resultMap>
<!--resultMap: resultMap 標簽中的 id 屬性值-->
<select id="selectUseResultMap" resultMap="studentMap">
select * from student where name=#{paramName} or
age=#{paramAge}
</select>
決議:
(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<Student> stuList = dao.selectUseResultMap(param);
stuList.forEach( stu -> System.out.println(stu));
}
3、物體類屬性名和列名不同的兩種處理方式
(1)使用< resultMap >
- 定義介面中的一個方法
List<MyStudent> selectMyStudent();
- 映射檔案
<resultMap id="myStudentMap" type="MyStudent">
<id column="id" property="stuid" />
<result column="name" property="stuname"/>
<result column="email" property="stuemail" />
<result column="age" property="stuage" />
</resultMap>
<select id="selectMyStudent" resultMap="myStudentMap">
select * from student
</select>
- 定義測驗方法
@Test
public void testSelectMyStudent(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
List<MyStudent> stuList = dao.selectMyStudent();
stuList.forEach( stu -> System.out.println("MyStudent="+stu));
}
(2)使用列別名和< resultType >
reultType的默認原則是:同名的列值賦值給同名的屬性,這里使用列別名(Java物件的屬性名)
- 定義介面中的一個方法
List<MyStudent> selectDiffColProperty();
- 映射檔案
<select id="selectDiffColProperty" resultType="MyStudent">
select id as stuid,name as stuname,email as stuemail,age as stuage
from student
</select>
- 定義測驗方法
@Test
public void testSelectDiffColProperty(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
List<MyStudent> stuList = dao.selectDiffColProperty();
stuList.forEach( stu -> System.out.println("MyStudent="+stu));
}
注意:resultType和resultMap不能一起使用,只能二選一
二、模糊查詢like
(1)在Java代碼中給查詢資料加上“%xxx%”(更方便)
- 定義介面中的一個方法
List<Student> selectLikeOne(String name);
- 映射檔案
<select id="selectLikeOne" resultType="Student">
select id,name,email,age from student where name like #{name }
</select>
- 定義測驗方法
@Test
public void testSelectLikeOne(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
//準備好like的內容
String name="%李%";
List<Student> stuList = dao.selectLikeOne(name);
stuList.forEach( stu -> System.out.println("OnelikeStudent="+stu));
}
(2)在映射檔案中的SQL陳述句的條件位置加上“%” #{xxx} “%”
- 定義介面中的一個方法
List<Student> selectLikeTow(String name);
- 映射檔案
<select id="selectLikeTow" resultType="Student">
select id,name,email,age from student where name like "%" #{name} "%"
</select>
- 定義測驗方法
@Test
public void testSelectLikeTow(){
SqlSession sqlSession = MyBatisUtil.getSqlSession();
StudentDao dao = sqlSession.getMapper(StudentDao.class);
String name="李";
List<Student> stuList = dao.selectLikeTow(name);
stuList.forEach( stu -> System.out.println("TowlikeStudent="+stu));
}
三、思維大綱

如有不足之處請大家指正哈!
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/252122.html
標籤:java
