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);
}
}
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);
}
使用方式:
(1)先定义resultMap,指定列名和属性的对应关系
(2)在<select>中把resultType替换为resultMap
List<Student> selectUseResultMap(QueryParam param);
<resultMap id="studentMap" type="Student">
<id column="id" property="id" />
<result column="name" property="name"/>
<result column="email" property="email" />
<result column="age" property="age" />
</resultMap>
<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));
}
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));
}
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不能一起使用,只能二选一
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);
String name="%李%";
List<Student> stuList = dao.selectLikeOne(name);
stuList.forEach( stu -> System.out.println("OnelikeStudent="+stu));
}
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));
}