前言

本文主要给大家介绍了关于mybatis注解映射SQL的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:
结果集分页
有时我们需要处理海量数据,由于数据量太大,所以不能一次取出所有的数据,这时我们就需要使用分页功能。mybatis通过RowBounds对象提供对分页的支持,如下所示:
<select id="findAllStudents" resultMap="StudentResult"> select * from studdents </select> int offset=0;//开始位置 int limit=25;//取出的数据条数 RowBounds rowBounds=new RowBounds(offset,limit); List<Student> list=studentMapper.findAllStudent(rowBounds);
结果处理器
有时我们需要对查询结果做一些特殊的处理,这个时候就需要结果处理器,举例如下,我们通过sql查询学生的stud_id和name,并期望返回一个map,其中key是stud_id,value是name.
新建一个接口:
public interface ResultHandler
{
void handleResult(ResultContext context);
}
主要处理流程:
Map<Integer , String> map=new HashMap<Integer,String>();
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查询,查询结果从缓存中取得而不是去查询数据库。
也可以通过<cache>标签配置二级缓存。当配置了二级缓存后,也就意味着所有的查询结果都会被缓存,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);
结果注解有一个缺点,就是在一个查询方法前面都要写一遍,不能重用。解决这个问题方案是:
定义一份结果映射文件如下所示:
<mapper namespace="com.mybatis3.mappers.StudentMapper">
<resultMap type="Student" id="StudentResult">
.......
</resultMap>
@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();
}
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# mybatis
# 注解sql
# mybatis注解sql语句
# sql映射
# Mybatis如何使用@Mapper和@MapperScan注解实现映射关系
# java 中MyBatis注解映射的实例详解
# MyBatis注解式开发映射语句详解
# 所示
# 分页
# 查询结果
# 内建
# 都是
# 如果你
# 相关内容
# 也就
# 说了
# 不多
# 一遍
# 可以通过
# 太大
# 给大家
# 很重要
# 这个时候
# 这篇文章
# 谢谢大家
# 第三方
# 它能
相关文章:
在线制作视频的网站有哪些,电脑如何制作视频短片?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何在Golang中引入测试模块_Golang测试包导入与使用实践
如何彻底删除建站之星生成的Banner?
如何在万网ECS上快速搭建专属网站?
建站中国官网:模板定制+SEO优化+建站流程一站式指南
济南专业网站制作公司,济南信息工程学校怎么样?
如何挑选优质建站一级代理提升网站排名?
南京网站制作费用,南京远驱官方网站?
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
盘锦网站制作公司,盘锦大洼有多少5G网站?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
重庆市网站制作公司,重庆招聘网站哪个好?
建站主机选购指南:核心配置与性价比推荐解析
如何通过虚拟机搭建网站?详细步骤解析
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
建站主机选虚拟主机还是云服务器更好?
如何设计高效校园网站?
怎么将XML数据可视化 D3.js加载XML
建站VPS推荐:2025年高性能服务器配置指南
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
ui设计制作网站有哪些,手机UI设计网址吗?
免费网站制作appp,免费制作app哪个平台好?
如何在IIS7中新建站点?详细步骤解析
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
如何快速搭建高效WAP手机网站?
建站之星如何防范黑客攻击与数据泄露?
建站之星如何助力网站排名飙升?揭秘高效技巧
台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?
北京网站制作网页,网站升级改版需要多久?
平台云上自助建站如何快速打造专业网站?
做企业网站制作流程,企业网站制作基本流程有哪些?
如何在云主机快速搭建网站站点?
建站VPS能否同时实现高效与安全翻墙?
c# 服务器GC和工作站GC的区别和设置
如何用PHP工具快速搭建高效网站?
官网建站费用明细查询_企业建站套餐价格及收费标准指南
如何在VPS电脑上快速搭建网站?
如何选择可靠的免备案建站服务器?
,在苏州找工作,上哪个网站比较好?
江苏网站制作公司有哪些,江苏书法考级官方网站?
官网自助建站系统:SEO优化+多语言支持,快速搭建专业网站
建站之星如何助力企业快速打造五合一网站?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?
如何通过PHP快速构建高效问答网站功能?
*请认真填写需求信息,我们会在24小时内与您取得联系。