java注解 sql_mybatis中注解映射SQL示例代码

前言

本文主要给大家介绍了关于mybatis注解映射SQL的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:

结果集分页

有时我们需要处理海量数据,由于数据量太大,所以不能一次取出所有的数据,这时我们就需要使用分页功能。mybatis通过RowBounds对象提供对分页的支持,如下所示:

select * from studdents

int offset=0;//开始位置

int limit=25;//取出的数据条数

RowBounds rowBounds=new RowBounds(offset,limit);

List list=studentMapper.findAllStudent(rowBounds);

结果处理器

有时我们需要对查询结果做一些特殊的处理,这个时候就需要结果处理器,举例如下,我们通过sql查询学生的stud_id和name,并期望返回一个map,其中key是stud_id,value是name.

新建一个接口:

public interface ResultHandler

{

void handleResult(ResultContext context);

}

主要处理流程:

Map map=new HashMap();

SqlSession sqlSession=MyBatisUtil.openSession();

sqlSession.select("com.mybatis3.mappers.StudentMapper.findAllStudents",new ResultHandler(){

public void handlerResult(ResultContext context)

{

Student student=(Student)context.getResultObject();

map.put(student.getStudId(),student.getName());

}

})

缓存

缓存对于很多应用来说都是很重要的,因为它能提高系统的性能。mybatis内建了缓存支持,默认情况下,一级缓存是打开的,即如果你使用相同的sqlSession接口调用相同的select查询,查询结果从缓存中取得而不是去查询数据库。

也可以通过标签配置二级缓存。当配置了二级缓存后,也就意味着所有的查询结果都会被缓存,insert,update,delete语句会更新缓存,cache的缓存管理算法是LRU。除了内建的缓存之外,mybatis还整合了第三方缓存框架例如Ehcache等。

注解@Insert @Update @Select @ Delete

举例说明注解的用法:

public interface StudentMapper

{

@Insert("insert into student (stud_id, name, email, addr_id, phone)values(#{studId},#{name},#{email},#{address.addrId},#{phone})")

int insertStudent(Student student);

}

public interface StudentMapper

{

@Insert("insert into student (name,email,addr_id,phone)values(#{name},#{email},#{address.addrId},#{phone})")

@Options(useGeneratedKeys=true,keyProperty="studId")

int insertStudent(Student student);

}

public interface StudentMapper

{

@Insert("insert into student (name,email,addr_id,phone)values(#{name},#{email},#{address.addrId},#{phone})")

@SelectKey(statement="select stud_id_seq.nextval from dual",keyProperty="studId",resultType=int.calss,before=true)

int insertStudent(Student student);

}

@Update("update students set name=#{name},email=#{email}")

int updateStudent(Student student);

@Delete("delete form students where stud_id=#{studId}")

int deleteStudent(int studId)

@Select("select name,email,phone from students where stud_id=#{studId}")

Student findStudentById(Integer studId);

结果注解

@Select("select name,email,phone from students where stud_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")

})

Student findStudentById(Integer studId);

结果注解有一个缺点,就是在一个查询方法前面都要写一遍,不能重用。解决这个问题方案是:

定义一份结果映射文件如下所示:

.......

@Select("select name,email,phone from students where stud_id=#{studId}")

@ResultMap("com.mybatis3.mappers.StudentMapper.StudentResult")

Student findStudentById(Integer studId);

动态Sql的注解

对于动态sql,mybatis提供了不同的注解,@InsertProvider @UpdateProvider @DeleteProvider @SelectProvider

用法如下所示:

首先创建一个provider类:

public class SqlProvider

{

public String findTutorById(int tutorId)

{

return "select tutorId,name,email from tutors where tutorId="+tutorId;

}

}

使用provider类:

@SelectProvider(type=SqlProvider.class,method="findTutorById")

Tutor findTutorById(int tutorId);

但是使用字符串连接创建sql语句容易出现问题,所以mybatis提供了一个SQL工具,简化了构建动态Sql的方式;

如下所示:

public class SqlProvider

{

public String findTutorById(int tutorId)

{

return new SQL(){{

SELECT("tutorid,name,email")

FROM("tutors")

WHERE("tutorid="+tutorId)

}}.toString();

}

}

或者

public class SqlProvider

{

public String findTutorById()

{

return new SQL(){{

SELECT("tutorid,name,email")

FROM("tutors")

WHERE("tutorid=#{tutorId}")

}}.toString();

}

}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值