资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

使用spring如何实现整合mybatis

今天就跟大家聊聊有关使用spring如何实现整合mybatis,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

创新互联是一家专业提供芜湖企业网站建设,专注与网站设计制作、成都网站设计H5建站、小程序制作等业务。10年已为芜湖众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

1、采用MapperScannerConfigurer,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。

spring-mybatis.xml:

<?xml version="1.0" encoding="UTF-8"?>

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  

 UserMapper.xml:

<?xml version="1.0" encoding="UTF-8" ?>



  
  
  

dao类:

/** 
* 这里的@MapperScan就是上面所讲的Mapper扫描器中所需要的配置,会自动生成代理对象。 
* 注意,接口中的方法名称要和对应的MyBatis映射文件中的语句的id值一样,因为生成的 
* 动态代理,会根据这个匹配相应的Sql语句执行。另外就是方法的参数和返回值也需要注 
* 意。接口中的方法如何定义,对应的MyBatis映射文件就应该进行相应的定义。 
* 最后,标注中的userDao是用来作为Spring的Bean的id(或name)进行使用的,方便我 
* 们在Service层进行注入使用。 
*/ 
@MapperScan
public interface UserDao {
  //此处的方法名必须和mapper中的映射文件中的id同名
  //回去映射文件中通过com.hua.saf.dao.UserDao.getUser,即this.getClass().getName()+".getUser"
  public User getUser(int id);
}

service类

@Service("userService")
public class UserServiceImpl implements IUserService {
@Resource
private UserDao userDao;
  public User getUser(int id) {
    return userDao.getUser(id);
  }
}

 2、采用接口org.apache.ibatis.session.SqlSession的实现类org.mybatis.spring.SqlSessionTemplate。

mybatis中, sessionFactory可由SqlSessionFactoryBuilder.来创建。MyBatis-Spring 中,使用了SqlSessionFactoryBean来替代。SqlSessionFactoryBean有一个必须属性dataSource,另外其还有一个通用属性configLocation(用来指定mybatis的xml配置文件路径)。

spring-mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

sqlMapConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
 
 
 
 
 

User.java

public class User {
 private int id;
 private String username;
 private String password;
 private int age;
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getUsername() {
 return username;
 }
 public void setUsername(String username) {
 this.username = username;
 }
 public String getPassword() {
 return password;
 }
 public void setPassword(String password) {
 this.password = password;
 }
 public int getAge() {
 return age;
 }
 public void setAge(int age) {
 this.age = age;
 }
}

UserDao.java

@Repository
public class UserDao{
 @Resource
 private SqlSessionTemplate sqlSessionTemplate;
 public User getUser(int id) {
 return sqlSessionTemplate.selectOne(this.getClass().getName() + ".getUser", 1);
 } 
}

UserService.java

@Service
public class UserService{
 @Resource
 private UserDao userDao;
 public User getUser(int id) {
 return userDao.getUser(id);
 }
}

3、采用抽象类org.mybatis.spring.support.SqlSessionDaoSupport提供SqlSession。

spring-mybatis.xml

<?xml version="1.0" encoding="UTF-8"?>

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

sqlMapConfig.xml

<?xml version="1.0" encoding="UTF-8"?>
 
 
 
 
 

User.java

public class User {
 private int id;
 private String username;
 private String password;
 private int age;
 public int getId() {
 return id;
 }
 public void setId(int id) {
 this.id = id;
 }
 public String getUsername() {
 return username;
 }
 public void setUsername(String username) {
 this.username = username;
 }
 public String getPassword() {
 return password;
 }
 public void setPassword(String password) {
 this.password = password;
 }
 public int getAge() {
 return age;
 }
 public void setAge(int age) {
 this.age = age;
 }
}

UserDao.java

@Repository
public class UserDao extends SqlSessionDaoSupport{
 public User getUser(int id) {
 return this.getSqlSession().selectOne(this.getClass().getName() + ".getUser", 1);
 }
  //使用SqlSessionDaoSupport必须注意,此处源码1.1.1中有自动注入,1.2中取消了自动注入,需要手工注入,侵入性强
  //也可在spring-mybatis.xml中如下配置,但是这种有多少个dao就要配置到少个,多个dao就很麻烦。
  //
  // 
  //
 @Resource
 public void setSqlSessionFactory(SqlSessionFactory sqlSessionFactory) {
 // TODO Auto-generated method stub
 super.setSqlSessionFactory(sqlSessionFactory);
 }
}

UserService.java

@Service
public class UserService{
 @Resource
 private UserDao userDao;
 public User getUserss(int id) {
 return userDao.getUser(1);
 }
}

看完上述内容,你们对使用spring如何实现整合mybatis有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


网页题目:使用spring如何实现整合mybatis
网页网址:http://cdkjz.cn/article/peehgj.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220