使用iBATIS3.0完成增删改查
iBATIS3.0和以前的版本有一些改变,不过学过以前版本的再学习3.0应该不是太难,3.0要求JDK1.5支持,因为其中增加了注解和泛型,这些都是JDK1.5才有的。好了废话不多说,先来利用iBATIS3做下简单的增删改查吧。
首先到Apache(http://www.apache.org/)网站下载iBATIS3的jar 包,我下载的是ibatis-3-core-3.0.0.227.zip,解压后吧那个jar文件(ibatis-3-core-3.0.0.227.jar)添加到工程就可以了,还有一个文件(ibatis-3-core-src-3.0.0.227.zip)是源代码,可以用来查看源代码的,使用eclipse可以用它来关联源代码。
在MyEclipse新建一个Java Project,结构如下图
在jdbc.properties文件是映射文件要使用的,其内容如下:
- driver=com.mysql.jdbc.Driver
- url=jdbc\:mysql\://localhost\:3306/test
- username=root
- password=123456
SqlMapper.xml是iBATIS的配置文件,其代码如下:
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEconfiguration
- PUBLIC"-//ibatis.apache.org//DTDConfig3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
- <configuration>
- <propertiesresource="jdbc.properties"/>
- <typeAliases>
- <typeAliastype="cn.ibatis3.test.Person"alias="Person"/>
- </typeAliases>
- <environmentsdefault="development">
- <environmentid="development">
- <transactionManagertype="JDBC"/>
- <dataSourcetype="POOLED">
- <propertyname="driver"value="${driver}"/>
- <propertyname="url"value="${url}"/>
- <propertyname="username"value="${username}"/>
- <propertyname="password"value="${password}"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapperresource="cn/ibatis3/test/person.xml"/>
- </mappers>
- </configuration>
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEconfiguration
- PUBLIC"-//ibatis.apache.org//DTDConfig3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
- <configuration>
- <propertiesresource="jdbc.properties"/>
- <typeAliases>
- <typeAliastype="cn.ibatis3.test.Person"alias="Person"/>
- </typeAliases>
- <environmentsdefault="development">
- <environmentid="development">
- <transactionManagertype="JDBC"/>
- <dataSourcetype="POOLED">
- <propertyname="driver"value="${driver}"/>
- <propertyname="url"value="${url}"/>
- <propertyname="username"value="${username}"/>
- <propertyname="password"value="${password}"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapperresource="cn/ibatis3/test/person.xml"/>
- </mappers>
- </configuration>
上面文件中的sql映射文件person.xml代码如下:
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEmapper
- PUBLIC"-//ibatis.apache.org//DTDMapper3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
- <!---->
- <mappernamespace="cn.ibatis3.test.PersonMapper">
- <selectid="selectPerson"parameterType="java.lang.Integer"
- resultType="Person">
- select*frompersonwhereid=#{id}
- </select>
- <selectid="selectAll"resultType="Person">
- select*fromperson
- </select>
- <selectid="selectPersonsByName"resultType="Person"parameterType="String">
- select*frompersonwherenamelike#{name}
- </select>
- <insertid="insertPerson"parameterType="Person">
- insertintoperson(name,birthday,sex)
- values(#{name},#{birthday},#{sex})
- </insert>
- <deleteid="deletePerson"parameterType="Person">
- deletefrompersonwhereid=#{id}
- </delete>
- <updateid="updatePerson"parameterType="Person">
- updatepersonsetname=#{name},birthday=#{birthday},sex=#{sex}
- whereid=#{id}
- </update>
- </mapper>
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEmapper
- PUBLIC"-//ibatis.apache.org//DTDMapper3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
- <!---->
- <mappernamespace="cn.ibatis3.test.PersonMapper">
- <selectid="selectPerson"parameterType="java.lang.Integer"
- resultType="Person">
- select*frompersonwhereid=#{id}
- </select>
- <selectid="selectAll"resultType="Person">
- select*fromperson
- </select>
- <selectid="selectPersonsByName"resultType="Person"parameterType="String">
- select*frompersonwherenamelike#{name}
- </select>
- <insertid="insertPerson"parameterType="Person">
- insertintoperson(name,birthday,sex)
- values(#{name},#{birthday},#{sex})
- </insert>
- <deleteid="deletePerson"parameterType="Person">
- deletefrompersonwhereid=#{id}
- </delete>
- <updateid="updatePerson"parameterType="Person">
- updatepersonsetname=#{name},birthday=#{birthday},sex=#{sex}
- whereid=#{id}
- </update>
- </mapper>
注意:在iBATIS3中,属性parameterMap是不推荐使用的,在以后的版本可能会去掉这个属性。
Person.java的代码如下:
- packagecn.ibatis3.test;
- importjava.util.Date;
- publicclassPerson{
- privateintid=0;
- privateStringname="";
- privateStringsex="male";
- privateDatebirthday=null;
- publicPerson(){
- }
- //省略getter和setter方法
- @Override
- publicStringtoString(){
- return"id="+id+"\t"+"name="+name+"\t"+"sex="+sex+"\t"
- +"birthday="+newjava.sql.Date(birthday.getTime()).toString();
- }
- }
- packagecn.ibatis3.test;
- importjava.util.Date;
- publicclassPerson{
- privateintid=0;
- privateStringname="";
- privateStringsex="male";
- privateDatebirthday=null;
- publicPerson(){
- }
- //省略getter和setter方法
- @Override
- publicStringtoString(){
- return"id="+id+"\t"+"name="+name+"\t"+"sex="+sex+"\t"
- +"birthday="+newjava.sql.Date(birthday.getTime()).toString();
- }
- }
iBATIS官方推荐我们使用单例模式创建一个sessionFactory,我这里也提供一个sessionFactory.java,呵呵,仅供参考:
- packagecn.ibatis3.test;
- importjava.io.IOException;
- importjava.io.Reader;
- importorg.apache.ibatis.io.Resources;
- importorg.apache.ibatis.session.SqlSessionFactory;
- importorg.apache.ibatis.session.SqlSessionFactoryBuilder;
- publicfinalclassSessionFactory{
- privateStringresource="cn/ibatis3/test/SqlMapper.xml";
- privateSqlSessionFactorysqlSessionFactory=null;
- privatestaticSessionFactorysessionFactory=newSessionFactory();
- privateSessionFactory(){
- try{
- Readerreader=Resources.getResourceAsReader(resource);
- sqlSessionFactory=newSqlSessionFactoryBuilder().build(reader);
- }catch(IOExceptione){
- System.out.println("#IOExceptionhappenedininitialisingtheSessionFactory:"+e.getMessage());
- thrownewExceptionInInitializerError(e);
- }
- }
- publicstaticSessionFactorygetInstance(){
- returnsessionFactory;
- }
- publicSqlSessionFactorygetSqlSessionFactory(){
- returnsqlSessionFactory;
- }
- }
- packagecn.ibatis3.test;
- importjava.io.IOException;
- importjava.io.Reader;
- importorg.apache.ibatis.io.Resources;
- importorg.apache.ibatis.session.SqlSessionFactory;
- importorg.apache.ibatis.session.SqlSessionFactoryBuilder;
- publicfinalclassSessionFactory{
- privateStringresource="cn/ibatis3/test/SqlMapper.xml";
- privateSqlSessionFactorysqlSessionFactory=null;
- privatestaticSessionFactorysessionFactory=newSessionFactory();
- privateSessionFactory(){
- try{
- Readerreader=Resources.getResourceAsReader(resource);
- sqlSessionFactory=newSqlSessionFactoryBuilder().build(reader);
- }catch(IOExceptione){
- System.out.println("#IOExceptionhappenedininitialisingtheSessionFactory:"+e.getMessage());
- thrownewExceptionInInitializerError(e);
- }
- }
- publicstaticSessionFactorygetInstance(){
- returnsessionFactory;
- }
- publicSqlSessionFactorygetSqlSessionFactory(){
- returnsqlSessionFactory;
- }
- }
基于接口的编程(还有就是iBATIS3的注解也是在接口方法上的,关于注解以后有机会再讲,它也是iBATIS3的一个新特性),DAO层的接口PersonMapper.java代码如下:
- packagecn.ibatis3.test;
- importjava.util.List;
- publicinterfacePersonMapper{
- PersonselectById(Integerid);
- List<Person>selectAll();
- List<Person>selectPersonsByName(Stringname);
- voidinsert(Personperson);
- voiddelete(Personperson);
- voidupdate(Personperson);
- }
- packagecn.ibatis3.test;
- importjava.util.List;
- publicinterfacePersonMapper{
- PersonselectById(Integerid);
- List<Person>selectAll();
- List<Person>selectPersonsByName(Stringname);
- voidinsert(Personperson);
- voiddelete(Personperson);
- voidupdate(Personperson);
- }
接口的实现类PersonDao.java代码如下:
- packagecn.ibatis3.test;
- importjava.util.ArrayList;
- importjava.util.List;
- importorg.apache.ibatis.session.SqlSession;
- importorg.apache.ibatis.session.SqlSessionFactory;
- publicclassPersonDaoimplementsPersonMapper{
- privateSqlSessionFactorysessionFactory=SessionFactory.getInstance()
- .getSqlSessionFactory();
- publicPersonselectById(Integerid){
- Personperson=newPerson();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- person=(Person)session.selectOne(
- "cn.ibatis3.test.PersonMapper.selectPerson",id);
- }finally{
- session.close();
- }
- returnperson;
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectAll(){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- persons=session
- .selectList("cn.ibatis3.test.PersonMapper.selectAll");
- }finally{
- session.close();
- }
- returnpersons;
- }
- publicvoiddelete(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.delete("cn.ibatis3.test.PersonMapper.deletePerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidinsert(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.insertPerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidupdate(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.updatePerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectPersonsByName(Stringname){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- System.out.println(name);
- persons=session.selectList(
- "cn.ibatis3.test.PersonMapper.selectPersonsByName","%"
- +name+"%");
- session.commit();
- }finally{
- session.close();
- }
- returnpersons;
- }
- }
- packagecn.ibatis3.test;
- importjava.util.ArrayList;
- importjava.util.List;
- importorg.apache.ibatis.session.SqlSession;
- importorg.apache.ibatis.session.SqlSessionFactory;
- publicclassPersonDaoimplementsPersonMapper{
- privateSqlSessionFactorysessionFactory=SessionFactory.getInstance()
- .getSqlSessionFactory();
- publicPersonselectById(Integerid){
- Personperson=newPerson();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- person=(Person)session.selectOne(
- "cn.ibatis3.test.PersonMapper.selectPerson",id);
- }finally{
- session.close();
- }
- returnperson;
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectAll(){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- persons=session
- .selectList("cn.ibatis3.test.PersonMapper.selectAll");
- }finally{
- session.close();
- }
- returnpersons;
- }
- publicvoiddelete(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.delete("cn.ibatis3.test.PersonMapper.deletePerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidinsert(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.insertPerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidupdate(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- session.insert("cn.ibatis3.test.PersonMapper.updatePerson",person);
- session.commit();
- }finally{
- session.close();
- }
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectPersonsByName(Stringname){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- System.out.println(name);
- persons=session.selectList(
- "cn.ibatis3.test.PersonMapper.selectPersonsByName","%"
- +name+"%");
- session.commit();
- }finally{
- session.close();
- }
- returnpersons;
- }
- }
最后是表的创建:
- DROPTABLEIFEXISTS`test`.`person`;
- CREATETABLE`test`.`person`(
- `id`int(10)unsignedNOTNULLauto_increment,
- `name`varchar(20)defaultNULL,
- `sex`varchar(8)defaultNULL,
- `birthday`datetimedefaultNULL,
- PRIMARYKEY(`id`)
- )ENGINE=InnoDBDEFAULTCHARSET=utf8;
- DROPTABLEIFEXISTS`test`.`person`;
- CREATETABLE`test`.`person`(
- `id`int(10)unsignedNOTNULLauto_increment,
- `name`varchar(20)defaultNULL,
- `sex`varchar(8)defaultNULL,
- `birthday`datetimedefaultNULL,
- PRIMARYKEY(`id`)
- )ENGINE=InnoDBDEFAULTCHARSET=utf8;
使用iBATIS3.0注解完成对数据库的简单操作
iBATIS3.0也增加了一些简单的注解,iBATIS3的注解只能完成一些简单操作,要进行更复杂的操作,最好是在XML文件中配置。
在数据库(本人使用的mysql)中建立一个person表:
- DROPTABLEIFEXISTS`test`.`person`;
- CREATETABLE`test`.`person`(
- `id`int(10)unsignedNOTNULLauto_increment,
- `name`varchar(20)defaultNULL,
- `sex`varchar(8)defaultNULL,
- `birthday`datetimedefaultNULL,
- PRIMARYKEY(`id`)
- )ENGINE=InnoDBDEFAULTCHARSET=utf8;
- DROPTABLEIFEXISTS`test`.`person`;
- CREATETABLE`test`.`person`(
- `id`int(10)unsignedNOTNULLauto_increment,
- `name`varchar(20)defaultNULL,
- `sex`varchar(8)defaultNULL,
- `birthday`datetimedefaultNULL,
- PRIMARYKEY(`id`)
- )ENGINE=InnoDBDEFAULTCHARSET=utf8;
在MyEclipse新建一个Java Project,结构如下图
在jdbc.properties文件是映射文件要使用的,其内容如下:
- driver=com.mysql.jdbc.Driver
- url=jdbc\:mysql\://localhost\:3306/test
- username=root
- password=123456
SqlMapper.xml是iBATIS的配置文件,其代码如下:
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEconfiguration
- PUBLIC"-//ibatis.apache.org//DTDConfig3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
- <configuration>
- <propertiesresource="jdbc.properties"/>
- <environmentsdefault="development">
- <environmentid="development">
- <transactionManagertype="JDBC"/>
- <dataSourcetype="POOLED">
- <propertyname="driver"value="${driver}"/>
- <propertyname="url"value="${url}"/>
- <propertyname="username"value="${username}"/>
- <propertyname="password"value="${password}"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapperresource="cn/ibatis3/test/annotation/person.xml"/>
- </mappers>
- </configuration>
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEconfiguration
- PUBLIC"-//ibatis.apache.org//DTDConfig3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
- <configuration>
- <propertiesresource="jdbc.properties"/>
- <environmentsdefault="development">
- <environmentid="development">
- <transactionManagertype="JDBC"/>
- <dataSourcetype="POOLED">
- <propertyname="driver"value="${driver}"/>
- <propertyname="url"value="${url}"/>
- <propertyname="username"value="${username}"/>
- <propertyname="password"value="${password}"/>
- </dataSource>
- </environment>
- </environments>
- <mappers>
- <mapperresource="cn/ibatis3/test/annotation/person.xml"/>
- </mappers>
- </configuration>
上面文件中的sql映射文件person.xml代码如下:
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEmapper
- PUBLIC"-//ibatis.apache.org//DTDMapper3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
- <mappernamespace="cn.ibatis3.test.annotation.PersonMapper">
- </mapper>
- <?xmlversion="1.0"encoding="UTF-8"?>
- <!DOCTYPEmapper
- PUBLIC"-//ibatis.apache.org//DTDMapper3.0//EN"
- "http://ibatis.apache.org/dtd/ibatis-3-mapper.dtd">
- <mappernamespace="cn.ibatis3.test.annotation.PersonMapper">
- </mapper>
注意:在iBATIS3中,命名空间(namespace)是必须的,如果不使用注解的话,名字可以自己定义。一旦使用了注解,这里必须是那个使用注解类或接口的全名。
Person.java的代码请参考我的《iBATIS3学习(一)》。
sessionFactory.java和我前面的《iBATIS3学习(一)》一样,只是注意将:
- privateStringresource="cn/ibatis3/test/SqlMapper.xml";
- privateStringresource="cn/ibatis3/test/SqlMapper.xml";
- 改为privateStringresource="cn/ibatis3/test/annotation/SqlMapper.xml";
- 改为privateStringresource="cn/ibatis3/test/annotation/SqlMapper.xml";
iBATIS3的注解可以定义在接口方法上的,也可以定义在类方法上,我这里定义在接口上,接口PersonMapper.java代码如下:
- packagecn.ibatis3.test.annotation;
- importjava.util.List;
- importorg.apache.ibatis.annotations.CacheNamespace;
- importorg.apache.ibatis.annotations.Delete;
- importorg.apache.ibatis.annotations.Insert;
- importorg.apache.ibatis.annotations.Options;
- importorg.apache.ibatis.annotations.Select;
- importorg.apache.ibatis.annotations.SelectProvider;
- importorg.apache.ibatis.annotations.Update;
- @CacheNamespace(readWrite=true)
- publicinterfacePersonMapper{
- @Select("select*frompersonwhereid=#{id}")
- @Options(useCache=true,flushCache=false)
- PersonselectById(Integerid);
- @SelectProvider(type=SqlProvider.class,method="selectAllSql")
- List<Person>selectAll();
- @Select("select*frompersonwherenamelike#{name}")
- List<Person>selectPersonsByName(Stringname);
- @Insert({"insertintoperson(name,birthday,sex)",
- "values(#{name},#{birthday},#{sex})"})
- voidinsert(Personperson);
- @Delete("deletefrompersonwhereid=#{id}")
- voiddelete(Personperson);
- @Update({"updatepersonsetname=#{name},birthday=#{birthday},sex=#{sex}",
- "whereid=#{id}"})
- voidupdate(Personperson);
- }
- packagecn.ibatis3.test.annotation;
- importjava.util.List;
- importorg.apache.ibatis.annotations.CacheNamespace;
- importorg.apache.ibatis.annotations.Delete;
- importorg.apache.ibatis.annotations.Insert;
- importorg.apache.ibatis.annotations.Options;
- importorg.apache.ibatis.annotations.Select;
- importorg.apache.ibatis.annotations.SelectProvider;
- importorg.apache.ibatis.annotations.Update;
- @CacheNamespace(readWrite=true)
- publicinterfacePersonMapper{
- @Select("select*frompersonwhereid=#{id}")
- @Options(useCache=true,flushCache=false)
- PersonselectById(Integerid);
- @SelectProvider(type=SqlProvider.class,method="selectAllSql")
- List<Person>selectAll();
- @Select("select*frompersonwherenamelike#{name}")
- List<Person>selectPersonsByName(Stringname);
- @Insert({"insertintoperson(name,birthday,sex)",
- "values(#{name},#{birthday},#{sex})"})
- voidinsert(Personperson);
- @Delete("deletefrompersonwhereid=#{id}")
- voiddelete(Personperson);
- @Update({"updatepersonsetname=#{name},birthday=#{birthday},sex=#{sex}",
- "whereid=#{id}"})
- voidupdate(Personperson);
- }
上面的注解SelectProvider使用了一个类SqlProvider.java,其代码如下:
- packagecn.ibatis3.test.annotation;
- publicclassSqlProvider{
- //动态的SQL语句,实际上应该使用iBATIS的动态SQL产生方法,这里仅仅是为了使用注解
- publicStringselectAllSql(){
- return"SELECT*FROMpersonp";
- }
- }
- packagecn.ibatis3.test.annotation;
- publicclassSqlProvider{
- //动态的SQL语句,实际上应该使用iBATIS的动态SQL产生方法,这里仅仅是为了使用注解
- publicStringselectAllSql(){
- return"SELECT*FROMpersonp";
- }
- }
接口的实现类PersonDao.java代码如下:
- packagecn.ibatis3.test.annotation;
- importjava.util.ArrayList;
- importjava.util.List;
- importorg.apache.ibatis.session.SqlSession;
- importorg.apache.ibatis.session.SqlSessionFactory;
- publicclassPersonDaoimplementsPersonMapper{
- privateSqlSessionFactorysessionFactory=SessionFactory.getInstance()
- .getSqlSessionFactory();
- publicPersonselectById(Integerid){
- Personperson=newPerson();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- person=personMapper.selectById(id);
- }finally{
- session.close();
- }
- returnperson;
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectAll(){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- persons=personMapper.selectAll();
- }finally{
- session.close();
- }
- returnpersons;
- }
- publicvoiddelete(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- personMapper.delete(person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidinsert(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- personMapper.insert(person);
- session.commit();
- }finally{
- session.close();
- }
- }
- publicvoidupdate(Personperson){
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- personMapper.update(person);
- session.commit();
- }finally{
- session.close();
- }
- }
- @SuppressWarnings("unchecked")
- publicList<Person>selectPersonsByName(Stringname){
- List<Person>persons=newArrayList<Person>();
- SqlSessionsession=null;
- try{
- session=sessionFactory.openSession();
- PersonMapperpersonMapper=session.getMapper(PersonMapper.class);
- persons=personMapper.selectPersonsByName("%"+name+"%");
- }finally{
- session.close();
- }
- returnpersons;
- }
- }