SpringMVC 学习 九 SSM环境搭建 (二) Spring配置文件的编写
spring配置文件中需要干的事情
(一)开启 Service与pojo包的注解扫描
注意:spring 扫描与表对应的实体类,以及service层的类,不能用来扫描Controller层的类,因为Controller层的类需要由SpringMVC容器来管理,如果采用了Spring容器管理,就会产生声明式事物无效
<context:component-scan base-package="com.ssm.pojo,com.ssm.bean,com.ssm.service.impl"></context:component-scan>
(二)spring整合mybatis的一些配置
(1)加载properties配置文件
<context:property-placeholder location="classpath:db.properties"/>
(2)配置数据源
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
<property name="driverClassName" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
(3)配置sqlSessionFactory
<!-- 配置sqlSessionFactory -->
<!-- sqlSessionFactory ,注册sqlSession工厂-->
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--dataSource的类型是DataSource是一个接口,上面配置的DriverManagerDataSouce类实现了DataSource接口 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 设置别名 -->
<property name="typeAliasesPackage" value="com.ssm.pojo"></property>
</bean>
(4)配置扫描器,用来扫描mybatis中xxxMapper.xml文件以及xxxMapper.java接口文件,并使用cglib的动态代理生成接口的实现类
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.ssm.mapper" ></property>
<!-- <property name="sqlSessionFactory" ref="factory"></property> -->
<property name="sqlSessionFactoryBeanName" value="sessionFactory"></property>
</bean>
(三)在开发中需要用到spring的声明式事物,配置事物
(1)配置事物管理器
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
(2)配置事物
<!-- 配置声明式事物,声明式事物需要和Aop一起使用,实际工作中会开启注解 -->
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<!-- 哪些方法需要有事务控制 -->
<!-- 方法以 ins 开头事务管理 -->
<tx:method name="ins*" />
<!-- 方法以 del 开头事务管理 -->
<tx:method name="del*" />
<!-- 方法以 upd 开头事务管理 -->
<tx:method name="upd*" />
<!-- readOnly
事务属性中的readOnly标志表示对应的事务应该被最优化为只读事务。
如果值为true就会告诉Spring我这个方法里面没有insert或者update,
你只需要提供只读的数据库Connection就行了,
这种执行效率会比read-write的Connection高,
所以这是一个最优化提示。
在一些情况下,一些事务策略能够起到显著的最优化效果
,例如在使用Object/Relational映射工具
(如:Hibernate或TopLink)时避免dirty checking(试图“刷新”)。 -->
<tx:method name="*" read-only="true"/>
</tx:attributes>
</tx:advice>
(3)配置切点和切面,注意execution里面的编写方法,返回值要与方法全路径之间有空格
<!--
声明式事物是基于AOP的,因此要声明切点和通知
-->
<aop:config>
<!-- 切点范围设置大一些 -->
<aop:pointcut expression="execution(* com.ssm.service.impl.*.*(..))" id="mypoint" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="mypoint" /> </aop:config>
(4)cglib的配置,如果在代码中有需要把代理类对象赋值给目标类对象的代码,此时动态代理需要使用cglib的动态代理,如果没有需要把代理对象赋值给目标对象,可以不用开启cglib
<!--
AOP的注解方式都是采用cglib动态代理
proxy-target-class="true"代表采用cglib动态代理
false代表使用jdk的动态代理
-->
<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy>
配置文件全文:
<?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:aop="http://www.springframework.org/schema/aop"
xmlns:context="http://www.springframework.org/schema/context"
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/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd">
<!-- 开启注解
注意:spring 扫描与表对应的实体类,以及service层的类,不能用来扫描Controller层的类,
因为Controller层的类需要由SpringMVC容器来管理,如果采用了Spring容器管理,
就会产生声明式事物无效
-->
<context:component-scan base-package="com.ssm.pojo,com.ssm.bean,com.ssm.service.impl"></context:component-scan> <!-- 加载属性文件 -->
<context:property-placeholder location="classpath:db.properties"/>
<!-- 配置数据源 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" >
<property name="driverClassName" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean> <!-- 配置sqlSessionFactory -->
<!-- sqlSessionFactory ,注册sqlSession工厂-->
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--dataSource的类型是DataSource是一个接口,上面配置的DriverManagerDataSouce类实现了DataSource接口 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 设置别名 -->
<property name="typeAliasesPackage" value="com.ssm.pojo"></property>
</bean> <!-- 扫描器,用来扫描mybatis中xxxMapper.xml文件以及xxxMapper.java接口文件,并使用cglib的动态代理生成接口的实现类 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.ssm.mapper" ></property>
<!-- <property name="sqlSessionFactory" ref="factory"></property> -->
<property name="sqlSessionFactoryBeanName" value="sessionFactory"></property>
</bean> <!-- 配置事物管理器 -->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean> <!-- 配置声明式事物,声明式事物需要和Aop一起使用,实际工作中会开启注解 -->
<tx:advice id="txAdvice" transaction-manager="txManager">
<tx:attributes>
<!-- 哪些方法需要有事务控制 -->
<!-- 方法以 ins 开头事务管理 -->
<tx:method name="ins*" />
<!-- 方法以 del 开头事务管理 -->
<tx:method name="del*" />
<!-- 方法以 upd 开头事务管理 -->
<tx:method name="upd*" />
<!-- readOnly
事务属性中的readOnly标志表示对应的事务应该被最优化为只读事务。
如果值为true就会告诉Spring我这个方法里面没有insert或者update,
你只需要提供只读的数据库Connection就行了,
这种执行效率会比read-write的Connection高,
所以这是一个最优化提示。
在一些情况下,一些事务策略能够起到显著的最优化效果
,例如在使用Object/Relational映射工具
(如:Hibernate或TopLink)时避免dirty checking(试图“刷新”)。 -->
<tx:method name="*" read-only="true"/>
</tx:attributes>
</tx:advice>
<!--
声明式事物是基于AOP的,因此要声明切点和通知
-->
<aop:config>
<!-- 切点范围设置大一些 -->
<aop:pointcut expression="execution(* com.ssm.service.impl.*.*(..))" id="mypoint" />
<aop:advisor advice-ref="txAdvice" pointcut-ref="mypoint" /> </aop:config>
<!--
AOP的注解方式都是采用cglib动态代理
proxy-target-class="true"代表采用cglib动态代理
false代表使用jdk的动态代理
-->
<aop:aspectj-autoproxy proxy-target-class="true"></aop:aspectj-autoproxy> </beans>
SpringMVC 学习 九 SSM环境搭建 (二) Spring配置文件的编写的更多相关文章
- SpringMVC 学习 十 SSM环境搭建(三)springMVC文件配置
SpringMVC文件配置的详细过程,可以查看springMVC环境搭建的注解配置篇<springMVC学习三 注解开发环境搭建> <?xml version="1.0&q ...
- SpringMVC 学习 八 SSM环境搭建(一) web.xml配置
第一步:导入jar包 注意包的兼容性,以后采用maven会好很多 第二步:配置web.xml 在web.xml中,主要的配置内容有以下几点 (1)spring容器配置文件的位置 <!-- spr ...
- spring+springMVC+mybatis+maven+mysql环境搭建(二)
上一篇整合了spring+mybatis,基本上还不是web工程,接下来接入springMVC,Let's go! 一.工程转换成Web工程 首先右击项目-->properties-->p ...
- rpc框架dubbo学习入门及环境搭建(spring boot+Kotlin)
学习之前,确保有以下知识基础: Java网络编程 Socket传输数据 IO流 rpc简介及实现 rpc是remote procedure call的简写,意思为远程过程调用. rpc应用较多的情景是 ...
- Java开发学习心得(一):SSM环境搭建
目录 Java开发学习心得(一):SSM环境搭建 1 SSM框架 1.1 Spring Framework 1.2 Spring MVC Java开发学习心得(一):SSM环境搭建 有一点.NET的开 ...
- 026 SSM综合练习02--数据后台管理系统--数据库表创建及SSM环境搭建
1.数据库准备 本项目我们Oracle数据库,Oracle 为每个项目创建单独user,oracle数据表存放在表空间下,每个用户有独立表空间. (1)采用数据库管理员账号:SYSTEM,再配合数据库 ...
- 黑马eesy_15 Vue:04.Vue案例(ssm环境搭建)
黑马eesy_15 Vue:02.常用语法 黑马eesy_15 Vue:03.生命周期 黑马eesy_15 Vue:04.Vue案例(ssm环境搭建) 黑马eesy_15 Vue:04.综合案例(前端 ...
- SSH环境搭建之Spring环境搭建篇
SSH环境搭建之Spring环境搭建篇 一.引入Spring所使用的JAR文件 二.在src目录下创建beans.xml(Spring的容器文件) <?xml version="1.0 ...
- 【golang学习记录】环境搭建
[golang学习记录]环境搭建 一. 概述 本文是[golang学习记录]系列文章的第一篇,安装Go语言及搭建Go语言开发环境,接下来将详细记录自己学习 go 语言的过程,一方面是为了巩固自己学到的 ...
随机推荐
- HTML5 WebSocket 权威指南 学习一 (第二章 WebSocket API)
WebSocket 协议两种URL方案 ws 客户端和服务器之间的非加密流量 wss 客户端和服务器之间的加密流量 WebSocket Secure 表示使用传输层安全性(SSL)的WebSocket ...
- Appium+python自动化4-等待函数
4.1 等待函数癈使用 4.1.1 为什么要使用等待函数 我们在做自动化的时候很多时候都不是很顺利,不是因为app的问题,我们的脚本也没问题,但是很多时候都会报错,比如一个页面本来就有id为1的这个元 ...
- MySQL千万级数据分区存储及查询优化
作为传统的关系型数据库,MySQL因其体积小.速度快.总体拥有成本低受到中小企业的热捧,但是对于大数据量(百万级以上)的操作显得有些力不从心,这里我结合之前开发的一个web系统来介绍一下MySQL数据 ...
- PAT L2-013 红色警报(并查集求连通子图)
战争中保持各个城市间的连通性非常重要.本题要求你编写一个报警程序,当失去一个城市导致国家被分裂为多个无法连通的区域时,就发出红色警报.注意:若该国本来就不完全连通,是分裂的k个区域,而失去一个城市并不 ...
- Nginx中超时时间配置(转)
本文介绍 Nginx 的 超时(timeout)配置.分享给大家,具体如下: Nginx 处理的每个请求均有相应的超时设置.如果做好这些超时时间的限定,判定超时后资源被释放,用来处理其他的请求,以此提 ...
- union和union all区别
如果我们需要将两个select语句的结果作为一个整体显示出来,我们就需要用到union或者union all关键字.union(或称为联合)的作用是将多个结果合并在一起显示出来. union和unio ...
- YII2中ActiveDataProvider与GridView的配合使用
YII2中ActiveDataProvider可以使用yii\db\Query或yii\db\ActiveQuery的对象,方便我们构造复杂的查询筛选语句. 配合强大的GridView,快速的显示我们 ...
- go语言net包rpc远程调用的使用
一.基于http的RPC 服务端: package main; import ( "net/rpc" "net/http" "log" ) ...
- 无法连接到localhost.其他信息:用户“sa”登录失败。(MicroSoft Sql Server,错误:18456)
18456错误: 在安装的时候如果选择的身份验证模式为:Window身份验证模式,就会出现18456的错误. 解决方案: 使用windows身份验证登录之后,在下面红框上单击右键,点击属性: 点击属性 ...
- 1S - 平方和与立方和
给定一段连续的整数,求出他们中所有偶数的平方和以及所有奇数的立方和. Input 输入数据包含多组测试实例,每组测试实例包含一行,由两个整数m和n组成. Output 对于每组输入数据,输出一行,应 ...