首页 > 其他分享 >Spring_day03

Spring_day03

时间:2022-12-02 21:31:24浏览次数:51  
标签:事务 day03 Spring springframework org import public


本篇主要内容

  1. Spring框架的AOP之注解的方式
  2. Spring框架的JDBC模板
  3. Spring框架的事务管理

案例一:使用Spring框架的AOP技术对DAO层的功能进行增强

1.Spring框架的AOP技术(注解方式)

Spring_day03_事务管理

  • 步骤一:创建JavaWEB项目,引入具体的开发的jar包
  • 先引入Spring框架开发的基本开发包
  • 再引入Spring框架的AOP的开发包
  • spring的传统AOP的开发的包
    *spring-aop-4.2.4.RELEASE.jar
    *com.springsource.org.aopalliance-1.0.0.jar
  • aspectJ的开发包
    *com.springsource.org.aspectj.weaver-1.6.8.RELEASE.jar
    *spring-aspects-4.2.4.RELEASE.jar
  • 步骤二:创建Spring的配置文件,引入具体的AOP的schema约束
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd">

</beans>
  • 步骤三:创建包结构,编写具体的接口和实现类
  • com.itheima.demo1
    *CustomerDao – 接口
    *CustomerDaoImpl – 实现类
  • 步骤四:将目标类配置到Spring中​​<bean id="customerDao" class="com.itheima.demo1.CustomerDaoImpl"/>​
  • 步骤五:定义切面类
  • 添加切面和通知的注解
  • @Aspect – 定义切面类的注解
  • 通知类型(注解的参数是切入点的表达式)
  • @Before – 前置通知
  • @AfterReturing – 后置通知
  • @Around – 环绕通知
  • @After – 最终通知
  • @AfterThrowing – 异常抛出通知
  • 具体的代码如下
package com.itheima.demo1;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;

/**
* 注解方式的切面类
*
* @author linmengmeng
*/

@Aspect
public class MyAspectAnno {

/**
* 通知类型:@Before前置通知(切入点的表达式)
*/
@Before(value = "MyAspectAnno.fn()")
public void log() {
System.out.println("日志记录。。。。");
}

/**
* 最终通知
*/
@After(value = "MyAspectAnno.fn()")
public void after() {
System.out.println("最终通知。。。。");
}

/**
* 自动定义切入点
*/
@Pointcut(value = "execution(public * com.itheima.demo1.CustomerDaoImpl.save())")
public void fn() {
}

@Around(value = "MyAspectAnno.fn()")
public void around(ProceedingJoinPoint joinPoint) {
System.out.println("环绕通知1.。。。");
try {
// 手动让目标方法执行
joinPoint.proceed();
} catch (Throwable e) {
e.printStackTrace();
}

System.out.println("环绕通知2.。。。");
}

}
  • 步骤六:在配置文件中定义切面类​​<bean id="myAspectAnno" class="com.itheima.demo1.MyAspectAnno"/>​
  • 步骤七:在配置文件中开启自动代理​​<aop:aspectj-autoproxy/>​
  • 完成测试
package com.itheima.demo1;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class Demo1 {

@Resource(name = "customerDao")
private CustomerDao customerDao;

@Test
public void run1() {
customerDao.save();
customerDao.update();
}
}

通知类型:

  • 通知类型
  • ​@Before​​ – 前置通知
  • ​@AfterReturing​​ – 后置通知
  • ​@Around​​ – 环绕通知(目标对象方法默认不执行的,需要手动执行)
  • ​@After​​ – 最终通知
  • ​@AfterThrowing​​ – 异常抛出通知
  • 配置通用的切入点
    *使用@Pointcut定义通用的切入点
@Aspect
public class MyAspectAnno {
@Before(value="MyAspectAnno.fn()")
public void log(){
System.out.println("记录日志...");
}
@Pointcut(value="execution(public void com.itheima.demo1.CustomerDaoImpl.save())")
public void fn(){}
}

案例二:Spring框架的事务管理完成转账的案例

Spring_day03_bc_02

  • Spring框架的JDBC模板技术概述
  1. Spring框架中提供了很多持久层的模板类来简化编程,使用模板类编写程序会变的简单
  2. 提供了JDBC模板,Spring框架提供的
    *JdbcTemplate类
  3. Spring框架可以整合Hibernate框架,也提供了模板类
    *HibernateTemplate类

演示JDBC的模板类
-
- 步骤一:创建数据库的表结构

create database spring_day03;
use spring_day03;
create table t_account(
id int primary key auto_increment,
name varchar(20),
money double
);
  • 引入开发的jar包
  • 先引入IOC基本的6个jar包(beans,context,core,expression,log4j,commons-logging)
  • 再引入Spring-aop的4个jar包(aop, aspects, aopalliances, aspectj-weaver)
  • 最后引入JDBC模板需要的jar包
    *MySQL数据库的驱动包
    *Spring-jdbc.jar
    *Spring-tx.jar
  • 编写测试代码(自己来new对象的方式)
package com.itheima.demo1;

import org.junit.Test;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DriverManagerDataSource;

/**
* 演示的JDBC的模板类
*
* @author linmengmeng
*
*/
public class Demo1 {

/**
* 演示模板类
*/
@Test
public void run1() {
// Spring框架提供了内置的连接池,不想使用内置,可整合其他的连接池
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql:///spring_day03");
dataSource.setUsername("root");
dataSource.setPassword("linmeng");

// 创建模板
JdbcTemplate template = new JdbcTemplate();
// 设置连接池
template.setDataSource(dataSource);

// 完成操作
template.update("insert into t_account values(null,?,?)", "冠希", 10000);

}
}

使用Spring框架来管理模板类

  • 刚才编写的代码使用的是new的方式,应该把这些类交给Spring框架来管理。
  • 修改的步骤如下
  • 步骤一:Spring管理内置的连接池
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///spring_day03"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
  • 步骤二:Spring管理模板类
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
  • 步骤三:编写测试程序
package com.itheima.demo1;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.sun.accessibility.internal.resources.accessibility;

/**
* 使用IOC的方式,测试JDBC的模板类
*
* @author linmengmeng
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class Demo1_1 {

@Resource(name = "jdbcTemplate")
private JdbcTemplate jdbcTemplate;

@Test
public void run1() {
jdbcTemplate.update("insert into t_account values(null,?,?)", "哈喽", 10000);
}

@Test
public void run2() {
jdbcTemplate.update("update t_account set name = ? where id=?", "哈喽1", 4);
}
}

Spring框架管理开源的连接池

  • 管理DBCP连接池
  • 先引入DBCP的2个jar包
    *com.springsource.org.apache.commons.dbcp-1.2.2.osgi.jar
    *com.springsource.org.apache.commons.pool-1.5.3.jar
  • 编写配置文件
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql:///spring_day03"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
  • 管理C3P0连接池
  • 先引入C3P0的jar包
    *com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar

*编写配置文件

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
<property name="jdbcUrl" value="jdbc:mysql:///spring_day03"/>
<property name="user" value="root"/>
<property name="password" value="root"/>
</bean>

Spring框架的JDBC模板的简单操作

  • 增删改查的操作
package com.itheima.demo1;

import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.sun.accessibility.internal.resources.accessibility;

/**
* 使用IOC的方式,测试JDBC的模板类
*
* @author linmengmeng
*/
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class Demo1_1 {

@Resource(name = "jdbcTemplate")
private JdbcTemplate jdbcTemplate;

@Test
public void run1() {
jdbcTemplate.update("insert into t_account values(null,?,?)", "哈喽", 10000);
}

@Test
public void run2() {
jdbcTemplate.update("update t_account set name = ? where id=?", "哈喽1", 4);
}

@Test
public void run3() {
jdbcTemplate.update("delete from t_account where id=?", 4);
}

/**
* 测试查询:通过主键查询一条记录
*/
@Test
public void run4() {
Account ac = jdbcTemplate.queryForObject("select * from t_account where id = ?", new BeanMapper(), 1);
System.out.println(ac);
}

/**
* 查询所有数据
*/
@Test
public void run5() {
List<Account> list = jdbcTemplate.query("select * from t_account ", new BeanMapper());
System.out.println(list);
}
}

/**
* 自己手动来封装数据,一行一行的封装
*
* @author linmengmeng
*
*/
class BeanMapper implements RowMapper<Account> {

@Override
public Account mapRow(ResultSet rs, int rowNum) throws SQLException {
Account ac = new Account();
ac.setId(rs.getInt("id"));
ac.setName(rs.getString("name"));
ac.setMoney(rs.getDouble("money"));
return ac;
}

}

Spring框架的事务管理

  • 事务的回顾
  1. 事务:指的是逻辑上一组操作,组成这个事务的各个执行单元,要么一起成功,要么一起失败!
  2. 事务的特性
  • 原子性
  • 一致性
  • 隔离性
  • 持久性
  1. 如果不考虑隔离性,引发安全性问题
  • 读问题:
  • 脏读:
  • 不可重复读:
  • 虚读:
  • 写问题:
  • 丢失更新:
  1. 如何解决安全性问题
  • 读问题解决,设置数据库隔离级别
  • 写问题解决可以使用 悲观锁和乐观锁的方式解决

Spring框架的事务管理相关的类和API

  1. PlatformTransactionManager接口 – 平台事务管理器.(真正管理事务的类)。该接口有具体的实现类,根据不同的持久层框架,需要选择不同的实现类!
  2. TransactionDefinition接口 – 事务定义信息.(事务的隔离级别,传播行为,超时,只读)
  3. TransactionStatus接口 – 事务的状态
  4. 总结:上述对象之间的关系:平台事务管理器真正管理事务对象.根据事务定义的信息TransactionDefinition 进行事务管理,在管理事务中产生一些状态.将状态记录到TransactionStatus中
  5. PlatformTransactionManager接口中实现类和常用的方法
    1.接口的实现类
    *如果使用的Spring的JDBC模板或者MyBatis框架,需要选择DataSourceTransactionManager实现类
    *如果使用的是Hibernate的框架,需要选择HibernateTransactionManager实现类
    2.该接口的常用方法
  • void commit(TransactionStatus status)
  • TransactionStatus getTransaction(TransactionDefinition definition)
  • void rollback(TransactionStatus status)
  1. TransactionDefinition
    1.事务隔离级别的常量
    *static int ISOLATION_DEFAULT – 采用数据库的默认隔离级别
    *static int ISOLATION_READ_UNCOMMITTED
    *static int ISOLATION_READ_COMMITTED
    *static int ISOLATION_REPEATABLE_READ
    *static int ISOLATION_SERIALIZABLE

2.事务的传播行为常量(不用设置,使用默认值)
*先解释什么是事务的传播行为:解决的是业务层之间的方法调用!!

*PROPAGATION_REQUIRED(默认值) -- A中有事务,使用A中的事务.如果没有,B就会开启一个新的事务,将A包含进来.(保证A,B在同一个事务中),默认值!!
*PROPAGATION_SUPPORTS -- A中有事务,使用A中的事务.如果A中没有事务.那么B也不使用事务.
*PROPAGATION_MANDATORY -- A中有事务,使用A中的事务.如果A没有事务.抛出异常.

*PROPAGATION_REQUIRES_NEW(记)-- A中有事务,将A中的事务挂起.B创建一个新的事务.(保证A,B没有在一个事务中)
*PROPAGATION_NOT_SUPPORTED -- A中有事务,将A中的事务挂起.
* PROPAGATION_NEVER -- A中有事务,抛出异常.
*PROPAGATION_NESTED(记) -- 嵌套事务.当A执行之后,就会在这个位置设置一个保存点.如果B没有问题.执行通过.如果B出现异常,运行客户根据需求回滚(选择回滚到保存点或者是最初始状态)

搭建事务管理转账案例的环境(强调:简化开发,以后DAO可以继承JdbcDaoSupport类)

  • 步骤一:创建WEB工程,引入需要的jar包
    *IOC的6个包
    *AOP的4个包
    *C3P0的1个包
    *MySQL的驱动包
    *JDBC目标2个包
    *整合JUnit测试包
  • 步骤二:引入配置文件
  • 引入配置文件
    *引入log4j.properties
    *引入applicationContext.xml
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
<property name="jdbcUrl" value="jdbc:mysql:///spring_day03"/>
<property name="user" value="root"/>
<property name="password" value="root"/>
</bean>
  • 步骤三:创建对应的包结构和类
  • com.itheima.demo1
    *AccountService
    *AccountServlceImpl
    *AccountDao
    *AccountDaoImpl
  • 步骤四:引入Spring的配置文件,将类配置到Spring中
<bean id="accountService" class="com.itheima.demo1.AccountServiceImpl">
</bean>

<bean id="accountDao" class="com.itheima.demo1.AccountDaoImpl">
</bean>
  • 步骤五:在业务层注入DAO ,在DAO中注入JDBC模板(强调:简化开发,以后DAO可以继承JdbcDaoSupport类)
<bean id="accountService" class="com.itheima.demo1.AccountServiceImpl">
<property name="accountDao" ref="accountDao"/>
</bean>

<bean id="accountDao" class="com.itheima.demo1.AccountDaoImpl">
<property name="dataSource" ref="dataSource"/>
</bean>
  • 步骤六:编写DAO和Service中的方法
public class AccountDaoImpl extends JdbcDaoSupport implements AccountDao {
public void outMoney(String out, double money) {
this.getJdbcTemplate().update("update t_account set money = money = ? where name = ?", money,out);
}
public void inMoney(String in, double money) {
this.getJdbcTemplate().update("update t_account set money = money + ? where name = ?", money,in);
}
}
  • 步骤七:编写测试程序.
package com.itheima.demo1;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext.xml")
public class Demo1 {

@Resource(name="accountService")
private AccountService accountService;
@Test
public void run1() {
//调用支付的方法
accountService.pay("冠希", "小凤", 1000);
}
}

Spring框架的事务管理的分类
1. Spring的编程式事务管理(不推荐使用)
* 通过手动编写代码的方式完成事务的管理(不推荐)
2. Spring的声明式事务管理(底层采用AOP的技术)
* 通过一段配置的方式完成事务的管理(重点掌握注解的方式)

Spring框架的事务管理之编程式的事务管理(了解)

​说明​​​:Spring为了简化事务管理的代码:提供了模板类
TransactionTemplate,所以手动编程的方式来管理事务,只需要使用该模板类即可!!

  • 手动编程方式的具体步骤如下:
    1.步骤一:配置一个事务管理器,Spring使用PlatformTransactionManager接口来管理事务,所以咱们需要使用到他的实现类!!
<!-- 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>

2.步骤二:配置事务管理的模板

<!-- 配置事务管理的模板 -->
<bean id="transactionTemplate" class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transactionManager"/>
</bean>

3.步骤三:在需要进行事务管理的类中,注入事务管理的模板.

<bean id="accountService" class="com.itheima.demo1.AccountServiceImpl">
<property name="accountDao" ref="accountDao"/>
<property name="transactionTemplate" ref="transactionTemplate"/>
</bean>

4.步骤四:在业务层使用模板管理事务:

// 注入事务模板对象
private TransactionTemplate transactionTemplate;
public void setTransactionTemplate(TransactionTemplate transactionTemplate) {
this.transactionTemplate = transactionTemplate;
}

public void pay(final String out, final String in, final double money) {
transactionTemplate.execute(new TransactionCallbackWithoutResult() {

protected void doInTransactionWithoutResult(TransactionStatus status) {
// 扣钱
accountDao.outMoney(out, money);
int a = 10/0;
// 加钱
accountDao.inMoney(in, money);
}
});
}

Spring框架的事务管理之声明式事务管理,即通过配置文件来完成事务管理(AOP思想)
1. 声明式事务管理又分成两种方式
* 基于AspectJ的XML方式(重点掌握)
* 基于AspectJ的注解方式(重点掌握)

基于AspectJ的XML方式(重点掌握)

  • 步骤一:恢复转账开发环境
  • 步骤二:引入AOP的开发包
  • 步骤三:配置事务管理器
<!-- 配置事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
  • 步骤四:配置事务增强
<!-- 配置事务增强 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!--
name :绑定事务的方法名,可以使用通配符,可以配置多个。
propagation :传播行为
isolation :隔离级别
read-only :是否只读
timeout :超时信息
rollback-for:发生哪些异常回滚.
no-rollback-for:发生哪些异常不回滚.
-->
<!-- 哪些方法加事务 -->
<tx:method name="pay" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
  • 步骤五:配置AOP的切面
<!-- 配置AOP切面产生代理 -->
<aop:config>
<aop:advisor advice-ref="myAdvice" pointcut="execution(* com.itheima.demo2.AccountServiceImpl.pay(..))"/>
</aop:config>

注意:如果是自己编写的切面,使用​​<aop:aspect>​​​标签,如果是系统制作的,使用​​<aop:advisor​​>标签。

  • 步骤六:编写测试类

完整配置文件applicationContext.xml :

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">

<!-- 配置C3P0连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
<property name="jdbcUrl" value="jdbc:mysql:///spring_day03"/>
<property name="user" value="root"/>
<property name="password" value="linmeng"/>
</bean>

<!-- 配置平台事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>

<!-- 声明式事务(采用xml配置文件的方式) -->
<!-- 先配置通知 -->
<tx:advice id="myAdvice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 给方法设置数据库属性(隔离级别,传播行为) -->
<tx:method name="pay" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>


<!-- 配置JDBC模板类 -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>

<!-- 配置业务层和持久层 -->
<bean id="accountService" class="com.itheima.demo2.AccountServiceImpl">
<property name="accountDao" ref="accountDao"/>
</bean>

<bean id="accountDao" class="com.itheima.demo2.AccountDaoImpl">
<property name="dataSource" ref="dataSource"/>
</bean>

</beans>

测试类:

package com.itheima.demo2;

import javax.annotation.Resource;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext2.xml")
public class Demo2 {

@Resource(name = "accountService")
private AccountService accountService;
@Test
public void run1() {
// 调用支付的方法
accountService.pay("冠希", "美美", 1000);
}
}

Spring框架的事务管理之基于AspectJ的注解方式(重点掌握,最简单的方式)

  • 步骤一:恢复转账的开发环境
  • 步骤二:配置事务管理器
<!-- 配置事务管理器  -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
  • 步骤三:开启注解事务
<!-- 开启注解事务 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
  • 步骤四:在业务层上添加一个注解:@Transactional
  • 编写测试类
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:applicationContext3.xml")
public class Demo3 {

@Resource(name="accountService")
private AccountService accountService;

@Test
public void run1(){
accountService.pay("冠希", "美美", 1000);
}
}

此篇博客由观看黑马视频28期视频之后整理得来。2018.06.13


标签:事务,day03,Spring,springframework,org,import,public
From: https://blog.51cto.com/linmengmeng/5907541

相关文章

  • SpringBoot整合Mybatis
    Springboot整合mybatis在Spring+SpringMVC中整合MyBatis步骤需要在配置文件里配置多个Bean,比如MapperScannerConfigurer,SqlSessionFactoryBean等,步骤还是比较复......
  • Eclipse配置springIDE插件、搭建测试环境、简单的demo
    1.Spring框架简介(以下这以下这段话可用于面试求职):Spring为JavaEE开发提供了一个轻量级的解决方案,主要表现为:IOC(或者叫做DI)的核心机制,提供了bean工厂(Spring容器),降低了业务......
  • Caused by: java.lang.NullPointerException at org.springframework.beans.factor
    在搭建完Spring环境之后运行第一个demo的时候就碰到这个问题,折腾了一天了,到现在才解决,记录一下自己的失误。解决办法就是在添加userLibrary的时候不能勾选SystemLibra......
  • day03--Scanner用户交互
    用户交互Scanner对象基本语法Scanners=newScanner(System.in);通过Scanner类的next()与nextLine()方法获取输入的字符串,再读取前我们一般需要使用hasNext()与ha......
  • 实现了Spring的Aware接口的自定义类什么时候执行的?
     在之前的内容中​​Spring的Aware接口有什么用?​​了解到用户可以通过实现相应的Aware接口来获取spring框架提供的能力,俗称“攀亲戚”以如下代码为例,自定义类MyAware实现......
  • 【JAVA】基于SpringSecurity登录的详细教程
    不知道抽起哪根筋,花了一周的时间终于写了个基于springsecurity的登录的样例,4、5年前在学springboot时曾经按书上的例子却怎么也写不出来,算是了却自己的一桩心愿吧。当然,我不......
  • Spring学习
    Spring学习1.Spring1.1简介Spring:春天—>给软件行业带来了春天2002年,RodJahnson首次推出了Spring框架雏形interface21框架。2004年3月24日,Spring框架以i......
  • SpringBoot
    自动装配原理从Spring的IOC到SpringBoot的自动装配原理DeferedImportSelector对Bean加载顺序的影响(当然是由@Import导入的)  DeferedImportSelector有一个分组的概念......
  • spring mvc环境之监听器、过滤器、拦截器(六)
    1.监听器Servlet的监听器Listener,它是实现了javax.servlet.ServletContextListener接口的服务器端程序,它也是随web应用的启动而启动,只初始化一次,随web应用的停止而销毁。......
  • SpringBoot Maven多模块项目 mapper.xml 文件扫描不到问题
    项目使用的是SpringBoot+MybatisPlus,maven多模块项目,其中有多个模块的resource下面有Mapper.xml文件。这点是问题的前提。。。。。在配置文件里面也指定了mybatis-plus......