mybatis中注解映射SQL示例代码
前言
本文主要给大家介绍了关于mybatis注解映射SQL的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:
结果集分页
有时我们需要处理海量数据,由于数据量太大,所以不能一次取出所有的数据,这时我们就需要使用分页功能。mybatis通过RowBounds对象提供对分页的支持,如下所示:
select*fromstuddents intoffset=0;//开始位置 intlimit=25;//取出的数据条数 RowBoundsrowBounds=newRowBounds(offset,limit); List list=studentMapper.findAllStudent(rowBounds);
结果处理器
有时我们需要对查询结果做一些特殊的处理,这个时候就需要结果处理器,举例如下,我们通过sql查询学生的stud_id和name,并期望返回一个map,其中key是stud_id,value是name.
新建一个接口:
publicinterfaceResultHandler
{
voidhandleResult(ResultContextcontext);
}
主要处理流程:
Mapmap=newHashMap (); SqlSessionsqlSession=MyBatisUtil.openSession(); sqlSession.select("com.mybatis3.mappers.StudentMapper.findAllStudents",newResultHandler(){ publicvoidhandlerResult(ResultContextcontext) { Studentstudent=(Student)context.getResultObject(); map.put(student.getStudId(),student.getName()); } })
缓存
缓存对于很多应用来说都是很重要的,因为它能提高系统的性能。mybatis内建了缓存支持,默认情况下,一级缓存是打开的,即如果你使用相同的sqlSession接口调用相同的select查询,查询结果从缓存中取得而不是去查询数据库。
也可以通过
注解@Insert@Update@Select@Delete
举例说明注解的用法:
publicinterfaceStudentMapper
{
@Insert("insertintostudent(stud_id,name,email,addr_id,phone)values(#{studId},#{name},#{email},#{address.addrId},#{phone})")
intinsertStudent(Studentstudent);
}
publicinterfaceStudentMapper
{
@Insert("insertintostudent(name,email,addr_id,phone)values(#{name},#{email},#{address.addrId},#{phone})")
@Options(useGeneratedKeys=true,keyProperty="studId")
intinsertStudent(Studentstudent);
}
publicinterfaceStudentMapper
{
@Insert("insertintostudent(name,email,addr_id,phone)values(#{name},#{email},#{address.addrId},#{phone})")
@SelectKey(statement="selectstud_id_seq.nextvalfromdual",keyProperty="studId",resultType=int.calss,before=true)
intinsertStudent(Studentstudent);
}
@Update("updatestudentssetname=#{name},email=#{email}")
intupdateStudent(Studentstudent);
@Delete("deleteformstudentswherestud_id=#{studId}")
intdeleteStudent(intstudId)
@Select("selectname,email,phonefromstudentswherestud_id=#{studId}")
StudentfindStudentById(IntegerstudId);
结果注解
@Select("selectname,email,phonefromstudentswherestud_id=#{studId}")
@Results({
@Result(id=true,column="stud_id",property="studId"),
@Result(column="name",property="name"),
@Result(column="email",property="email"),
@Result(column="phone",property="phone")
})
StudentfindStudentById(IntegerstudId);
结果注解有一个缺点,就是在一个查询方法前面都要写一遍,不能重用。解决这个问题方案是:
定义一份结果映射文件如下所示:
....... @Select("selectname,email,phonefromstudentswherestud_id=#{studId}") @ResultMap("com.mybatis3.mappers.StudentMapper.StudentResult") StudentfindStudentById(IntegerstudId);
动态Sql的注解
对于动态sql,mybatis提供了不同的注解,@InsertProvider@UpdateProvider@DeleteProvider@SelectProvider
用法如下所示:
首先创建一个provider类:
publicclassSqlProvider
{
publicStringfindTutorById(inttutorId)
{
return"selecttutorId,name,emailfromtutorswheretutorId="+tutorId;
}
}
使用provider类:
@SelectProvider(type=SqlProvider.class,method="findTutorById") TutorfindTutorById(inttutorId);
但是使用字符串连接创建sql语句容易出现问题,所以mybatis提供了一个SQL工具,简化了构建动态Sql的方式;
如下所示:
publicclassSqlProvider
{
publicStringfindTutorById(inttutorId)
{
returnnewSQL(){{
SELECT("tutorid,name,email")
FROM("tutors")
WHERE("tutorid="+tutorId)
}}.toString();
}
}
或者
publicclassSqlProvider
{
publicStringfindTutorById()
{
returnnewSQL(){{
SELECT("tutorid,name,email")
FROM("tutors")
WHERE("tutorid=#{tutorId}")
}}.toString();
}
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。