Spring整合MyBatis
1.1添加依赖
首先,确保在项目中引入Spring和MyBatis的依赖。我们使用的是Maven来管理我们的依赖
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.3.10.RELEASE</version>
</dependency>
<!-- MyBatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.7</version>
</dependency>
1.2xml配置
编写applicationContext.xml
引入了spring依赖才可以创建有spring树叶标志的xml文件
mybatis作为持久层的框架,spring整合mybatis需要管理数据源(连接池), 管理 SqlSessionFactoryBean,管理接口绑定三部分。 下面为xml配置
1.2.1配置数据源
id:dataSource 固定的
连接池可以选择:
1.spring自带的连接池(org.springframework.jdbc.datasource.DriverManagerDataSource)
2.第三方的连接池(例如:com.alibaba.druid.pool.DruidDataSource)
配置数据库连接参数:驱动,url,username,password
<context:property-placeholder location="classpath:db.properties"/>
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!--com.alibaba.druid.pool.DruidDataSource-->
<property name="driverClassName" value="${mysql.driver}"/>
<property name="url" value="${mysql.url}"/>
<property name="username" value="${mysql.username}"/>
<property name="password" value="${mysql.password}"/>
</bean>
1.2.2 spring管理SqlSessionFactoryBean
SqlSessionFactoryBean中getObject()方法返回SqlSessionFactory,
通过SqlSessionFactory获取SqlSession
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 数据源 -->
<property name="dataSource" ref="dataSource"/>
<!-- 定义别名 -->
<property name="typeAliasesPackage" value="com.zqwl.pojo"/>
</bean>
SqlSessionFactoryBean中getObject()方法返回SqlSessionFactory,通过SqlSessionFactory获取SqlSession
1.2.3 Spring 管理接口绑定
<!-- Spring 管理接口绑定 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 指定映射接口的包 -->
<property name="basePackage" value="com.zqwl.mapper"/>
<!-- sqlSessionFactory -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean
这个部分配置了MyBatis的Mapper接口的扫描和绑定。 定义了一个MapperScannerConfigurer,并配置了要扫描的Mapper接口包(basePackage)以及要使用的SqlSessionFactory(sqlSessionFactoryBeanName)。
MapperScannerConfigurer 负责扫描指定包下的Mapper接口,并自动创建代理对象,将它们绑定到SqlSessionFactory。这样,你可以直接在业务代码中使用这些Mapper接口来访问数据库,而无需手动实现SQL语句的执行。
1.3使用注解配置
注解名称 | 解释 |
---|---|
@Component | 实例化Bean,默认名称为类名首字母变小写(类名不要出现类似AServiceImpl)。支持自定义名称 |
@Repository | @Component子标签,作用和@Component一样,用在持久层。 |
@Service | @Component子标签,作用和@Component一样,用在业务层。 |
@Controller | @Component子标签,作用和@Component一样,用在控制器层。 |
@Configuration | @Component子标签,作用和@Component一样,用在配置类。 |
@Autowired | 自动注入。默认byType,如果多个同类型bean,使用byName(默认通过属性名查找是否有同名的bean,也可以通过@Qualifier(“bean名称”),执行需要注入的Bean名称) |
@Resource | 非Spring注解。默认byName,如果没找到,使用byType。 |
主要的区别是语义上的区别。当看到不同的注解放在不同层的类中。但是不按照语义去做,非把@Service用在持久层,也是有效果的。但是这样却是不规范的。
最重要的一个:最常用
使用注解注入Mapper
在Service类中使用@Autowired注解来完成注入,然后可以调用Mapper中的方法。
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public User getUserById(int id) {
return userMapper.getUserById(id);
}
}
xml中的自动注入需要依赖于set方法,而注解中的自动注入会因为放置的位置不同而变化
注解放在有参构造方法上面就通过有参构造函数完成。
public class MyBean {
private AnotherBean anotherBean;
@Autowired
public MyBean(AnotherBean anotherBean) {
this.anotherBean = anotherBean;
}
}
放在属性上和放在无参构造时默认使用反射
public class MyBean {
@Autowired
private AnotherBean anotherBean;
}
注解放在set方法上使用set方法注入
Spring Test 模块
// 使用Spring整合Junit4的类启动当前测试类
@RunWith(SpringJUnit4ClassRunner.class)
// 启动时加载的配置文件,里面要包含classpath
@ContextConfiguration(locations = "classpath:applicatonContext.xml")
public class MyTest {
@Autowired
PeopleService peopleService;
@Test
public void test2(){
peopleService.test();
}
}
2.Spring整合web
只说一下配置监听器
在web.xml中配置监听器,让web项目启动时自动创建Spring容器对象(WebApplicationContext)。
上下文参数名param-name的值是固定的contextConfigLocation。这个值是监听器需要获取的值。
上下文参数值需要带有classpath,表示加载类路径内容。target/classes目录内容。
classpath*:表示当前项目依赖的jar中资源也会寻找。
classpath:后面的值支持星号。例如applicationContext-*.xml
表示加载所有以applicationContext-开头的xml文件。
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!-- 监听ServletContext对象,对象创建时会加载Spring的配置文件,创建Spring容器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
获取容器的方法
WebApplicationContext wac = WebApplicationContextUtils.getWebApplicationContext(req.getServletContext());
如果你有任何问题、意见或建议,都欢迎在评论中分享。让我们继续分享知识,共同成长,一起走向更加美好的未来。感谢你们的阅读,祝愿你们在未来的道路上一帆风顺!