Spring和MaBatis整合(xml版与纯注解版)
创始人
2025-05-30 06:50:46
0

Spring和MyBatis整合xml版:

先瞅一眼各种文件路径:
在这里插入图片描述

  • 将之前mybatis中的测试类中的SqlSessionFactory(通过其openSession()来获得对象SqlSession),和Mybatis配置文件中的数据源(url,username等)揉在一起放入Spring配置文件中,对了,还有指定MyBatis核心配置文件的位置
  • 将Mapper接口放进去,扫描包含接口的包,会自动生成实现类
  • 将之前MyBatis中的创建接口代理的代码放入Spring中
  • 将之前Spring中的properties文件放进去
  • 将所需要的包扫描(讲几个层和Mapper接口放进去)
  • 事务管理
   






从测试类开始看:Dao,Service类等等都加入了注解,调用业务层的实现类

import com.itjh.pojo.Dao;
import com.itjh.service.ServiceDao;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import java.util.List;public class Test01 {public static void main(String[] args) {ApplicationContext applicationContext =new ClassPathXmlApplicationContext("springConfig.xml");ServiceDao serviceDao=(ServiceDao) applicationContext.getBean("servicedaoimple");List daos = serviceDao.selectall(1);System.out.println(daos);}
}

看业务层的实现类之前先看看其实现的接口:这个接口定义了调用数据的方法,方便实现类ServiceDaoImple重写了这些方法之后对数据进行调用(Dao类的里面数据)

package com.itjh.service;import com.itjh.pojo.Dao;
import java.util.List;public interface ServiceDao {int add(Dao dao);List selectall(int id);}

再看实现类:通过给方法传递参数来让方法中的调用成功,当然方法中的调用需要到另一个接口Mapper,于是用到 @Autowired来代替之前配置文件中的标签,有了这个接口的注入

package com.itjh.service;import com.itjh.mapper.mapper;
import com.itjh.pojo.Dao;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;import java.util.List;@Transactional
@Service("servicedaoimple")
public class ServiceDaoImple implements ServiceDao{public ServiceDaoImple(){System.out.println("巴黎");}@Autowiredpublic mapper map;public int add(Dao dao) {return map.insert(dao);}public List selectall(int id) {System.out.println("茜茜");return map.selectall(id);}
}

来到Mapper接口中:在最开始的那个Spring配置文件中扫描接口的标签由于会自动生成接口的实现类,过程中就将位置一样的Mapper映射文件与Mapper接口的实现类挂钩了,于是实现了再业务层中对于Mapper接口的方法成功调用后,由于其实现类和映射文件的关系,就自动的进入映射文件中找到和接口方法相同的id,执行sql语句

package com.itjh.mapper;import com.itjh.pojo.Dao;import java.util.List;public interface mapper {int insert(Dao dao);List selectall(int id);
}

Mapper映射文件:



insert into bank (name,age) values (#{name},#{age})

对了还有MyBatis核心配置文件:不过里面的数据源标签,扫描映射文件标签都没了(映射文件加载变成现在的Spring配置文件中对于包含接口的包的扫描产生实现类,且由于接口与映射文件路径相同,于是加载出了映射文件),就简单的加一个日志:



insert into bank (name,age) values (#{name},#{age})

最后还有properties文件:用于搭配Spring配置文件中的数据源中${}

梳理一遍:

整体流程: 将参数从测试类传进业务层的实现类(方法由业务层的接口来定义,业务层实现类实现),再传进Mapper接口的方法,再因为其实现类和映射文件的关系,直接进入了映射文件进行sql语句的执行

Spring和MyBatis整合纯注解版:

将原本xml中的配置全部抽离出来:

  • 数据源
  • 将数据源放入SqlSessionFactoryBean对象中并且返回
  • MapperScannerConfigurer来加载Mapper接口(接口和Mapper映射文件同路径)
  • xml型的扫描和propertis文件现在放在纯注解的配置类上

数据源(SpringCofig类)与propertis文件:应当引用import javax.sql.DataSource;别和import javax.activation.DataSource;混淆了,二者不同点

package com.springcofig;import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import javax.sql.DataSource;public class SpringCofig {@Value("${jdbc.Driver}")private String driver;@Value("${jdbc.url}")private String url;@Value("${jdbc.username}")private String username;@Value("${jdbc.password}")private String password;@Beanpublic DataSource dataSource() {DruidDataSource dataSource = new DruidDataSource();dataSource.setUsername("root");dataSource.setPassword("123456");dataSource.setUrl("jdbc:mysql://localhost:3306/parent?useSSL=false");dataSource.setDriverClassName("com.mysql.jdbc.Driver");return dataSource;}
}

propertis文件

jdbc.username=root
jdbc.Driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql:///parent
jdbc.password=123456

MyBatis核心文件的注解型:看上面第一段话的二三行

  • public SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource)中的DataSource属于引用类型,会自动的在容器中寻找DataSource的bean,而SpringCofig类已经用@Bean注册了DataSource,所以这里就可以直接注入了,代替了配置文件中的标签
  • MapperScannerConfigurer扫描的是包含接口的包,会自动生成实现类
package com.springcofig;import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.mapper.MapperScannerConfigurer;
import org.springframework.context.annotation.Bean;
import javax.sql.DataSource;public class MybatisConfig {@Beanpublic SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource){SqlSessionFactoryBean sqlSessionFactoryBean=new SqlSessionFactoryBean();sqlSessionFactoryBean.setDataSource(dataSource);return sqlSessionFactoryBean;}@Beanpublic MapperScannerConfigurer mapperScannerConfigurer(){MapperScannerConfigurer mapperScannerConfigurer=new MapperScannerConfigurer();mapperScannerConfigurer.setBasePackage("com.mapp");return mapperScannerConfigurer;}
}

Mapper接口:使用注解的方式代替了映射文件繁琐的sql语句,当然只有语句简单的情况下才会用注解的方式而不用映射文件的方式

package com.mapp;import com.pojo.User;
import org.apache.ibatis.annotations.Select;
import java.util.List;public interface Mapperinter {@Select("select * from bank")List selectall();
}

然后就业务层的接口和实现类:

package com.service;import com.pojo.User;import java.util.List;public interface ServiceIm {public List selectall();
}
package com.service;import com.mapp.Mapperinter;
import com.pojo.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;@Service
public class ServiceImplement implements ServiceIm {@Autowiredprivate Mapperinter mapperinter;public List selectall() {return mapperinter.selectall();}
}

上面实现类所调用的Mapper接口:返回值为集合

package com.mapp;import com.pojo.User;
import org.apache.ibatis.annotations.Select;
import java.util.List;public interface Mapperinter {@Select("select * from bank")List selectall();
}

User数据层:

package com.pojo;import org.springframework.context.annotation.ComponentScan;
import org.springframework.stereotype.Component;@Component
public class User {private int age;private String name;private String gander;private int id;public int getAge() {return age;}public void setAge(int age) {this.age = age;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getGander() {return gander;}public void setGander(String gander) {this.gander = gander;}public int getId() {return id;}public void setId(int id) {this.id = id;}@Overridepublic String toString() {return "User{" +"age=" + age +", name='" + name + '\'' +", gander='" + gander + '\'' +", id=" + id +'}';}
}

测试类:

import com.config;
import com.pojo.User;
import com.service.*;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;import java.util.List;public class TestDay01 {public static void main(String[] args) {ApplicationContext applicationContext =new AnnotationConfigApplicationContext(config.class);ServiceIm serviceIm =(ServiceIm) applicationContext.getBean(ServiceImplement.class);List list=serviceIm.selectall();System.out.println(list);}
}

总结:主线任务是调用bean类型为ServiceImplement.class的方法,然后调用其中的方法,然后会进入到Mapper接口,得到需要的东西
支线任务是那些Spring配置类MyBatis配置类等等都是给上面提供各种条件

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...