欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

mybatis中注解映射SQL示例代码

程序员文章站 2024-02-24 20:43:10
前言 本文主要给大家介绍了关于mybatis注解映射sql的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍: 结果集分页 有时我们需要处理...

前言

本文主要给大家介绍了关于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();
  }
 } 

总结

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