IOC容器赋值:如果是简单类型(8个基本+String),value;
如果是对象类型,ref="需要引用的id值 ",因此实现了对象与对象之间的依赖关系
conext.getBean(需要获取的bean的id值)
依赖注入3种方式:
1
.set方式的依赖注入:通过setXxx()赋值
赋值,默认使用的是set方法();
依赖注入底层是通过反射实现的。
<property>
2.
构造器注入:通过构造方法赋值
<constructor-arg value="ls" type="String" index="0" name="name"></constructor-arg>
需要注意:如果<constructor-arg>的顺序与构造方法参数的顺序不一致,则需要通过type或者index或name指定。
3.
p命名空间注入:引入p命名空间
xmlns:p="http://www.springframework.org/schema/p"
<bean id ="course" class="org.langqiao.entity.Course" p:courseHour="300" p:courseName="hadoop" p:teacher-ref="teacher">
简单类型:
p:属性名="属性值"
引用类型(除了String外):
p:属性名-ref="引用的id"
注意多个p赋值的时候要有空格。
注意:
无论是String还是Int/short/long,在赋值时都是value="值"
因此建议 此种情况需要配合name\type进行区分
示例:
注入各种集合数据类型:List Set map properties
set,list,数组 各自都有自己的标签<set><list><array>,但是也可以混着用。
给对象类型赋null:
<property name="name">
<null/> -->注意 没有<value>
<property>
赋空值 " "
<property name ="name">
<value></value>
</property>
在ioc中定义bean的前提是:该bean的类必须提供了无参构造
自动装配(只适用于ref类型):
约定优于配置
自动装配:
<bean ... class="org.lanqiao.entity.Course" autowire="byName|byType|constructor|no"> byName本质是byId
byName:自动寻找:其他bean的id值=该Course类的属性名
byType:其他bean的类型(class)是否与该Course类的ref属性类型一致(注意,此种方式必须满足:当前Ioc容器中只能有一个Bean满足条件)
constructor:其他bean的类型(class)是否与该Course类的构造方法参数的类型一致;此种方式的本质就是byType
可以在头文件中一次性将该ioc容器的所有bean 统一设置成自动装配:
<beans xmlns="http://www.springframework.org/schema/beans"
...
default-autowire="byName">
自动装配虽然可以减少代码量,但是会降低程序的可读性,使用时需要谨慎。
使用注解定义bean:通过注解的形式将bean以及相应的属性值放入ioc容器
<context:component-scan base-package="org.lanqiao.dao">
</context:component-scan>
Spring在启动的时候,会根据base-package在该包中扫描所有类,查找这些类是否有注解@Component("studentDao"),如果有,则将该类加入spring Ioc容器。
@Component细化:
dao层注解:@Repository
service层注解:@Service
控制器层注解:@Controller
使用注解实现事务(声明式事务)
目标:通过事务使以下方法要么全成功,要么全失败
public void addStudent(){
//增加班级
//增加学生
//crdu
}
a. jar包
spring-tx-4.3.9.RELEASE
ojdbc.jar
连接池使用到数据源
commons-pool.jar 连接池
spring-jdbc-4.3.9.RELEASE.jar
aopalliance.jar
b.配置
jdbc\mybatis\spring
增加事务tx的命名空间
<!--增加对事务的支持-->
<tx:annotation-driven transaction-manager="txManager" />
c.使用
将需要成为事务的方法前增加注解:
@Transactional(readOnly=false,propagation=Propagation.REQUIRED)
<!-- 配置扫描器 -->
<!--
<context:component-scan base-package=""></context:component-scan>
-->
<!-- 配置数据库相关 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"></bean>
<!-- 配置事务管理器txManager -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 增加对事务的支持 -->
<tx:annotation-driven transaction-manager="txManager"/>
AOP名词解释
Transactional注解的属性