spring-datesource.xml配置,spring集成mybatis

2024-01-24 21:38

本文主要是介绍spring-datesource.xml配置,spring集成mybatis,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

搭建spring应用项目时,如果持久层使用iBatis框架的话,需要集成mybatis。

下面粘贴出spring-mybatis.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:tx="http://www.springframework.org/schema/tx"xmlns:aop="http://www.springframework.org/schema/aop"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop.xsd"><!-- 配置数据源、连接池--><bean name="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"><property name="driverClassName" value="${datasource.driver}"/><property name="url" value="${datasource.url}"/><property name="username" value="${datasource.username}"/><property name="password" value="${datasource.password}"/><!-- 初始化连接大小 --><property name="initialSize" value="${datasource.initialSize}"/><!-- 连接池最大使用连接数量 --><property name="maxActive" value="${datasource.maxActive}"/><!-- 连接池最小空闲 --><property name="minIdle" value="${datasource.minIdle}"/><!-- 获取连接最大等待时间 --><property name="maxWait" value="${datasource.maxWait}"/><!-- 打开PSCache,并且指定每个连接上PSCache的大小 --><!--<property name="poolPreparedStatements" value="${datasource.poolPreparedStatements}" /> --><!--<property name="maxPoolPreparedStatementPerConnectionSize" value="datasource.maxPoolPreparedStatementPerConnectionSize" /> --><!-- 用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用。 --><property name="validationQuery" value="${datasource.validationQuery}"/><!-- 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。 --><property name="testOnBorrow" value="${datasource.testOnBorrow}"/><property name="testOnReturn" value="${datasource.testOnReturn}"/><!-- 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。 --><property name="testWhileIdle" value="${datasource.testWhileIdle}"/><!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 --><property name="timeBetweenEvictionRunsMillis" value="${datasource.timeBetweenEvictionRunsMillis}"/><!-- 配置一个连接在池中最小生存的时间,单位是毫秒 --><property name="minEvictableIdleTimeMillis" value="${datasource.minEvictableIdleTimeMillis}"/><!-- 打开removeAbandoned功能 --><property name="removeAbandoned" value="${datasource.removeAbandoned}"/><!-- 数据库连接自动回收,1800秒,也就是30分钟 --><property name="removeAbandonedTimeout" value="${datasource.removeAbandonedTimeout}"/><!-- 关闭abanded连接时输出错误日志 --><property name="logAbandoned" value="${datasource.logAbandoned}"/><!-- 监控数据库 --><!-- <property name="filters" value="stat" /> --><property name="filters" value="${datasource.filters}"/></bean><!-- myBatis文件 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource"/><!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 --><!--<property name="mapperLocations" value="classpath:mybatis/mapper/*.xml"/>--><!-- 加入mybatis配置 --><property name="configLocation" value="classpath:mybatis/mybatis-config.xml"/><!-- 实体 --><property name="typeAliasesPackage" value="com.ssm.model"/></bean><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 自动扫描包名 --><property name="basePackage" value="com.ssm.dao"/><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/></bean><!-- 配置事务管理器 --><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/></bean><!-- 注解方式配置事物 --><tx:annotation-driven transaction-manager="transactionManager"/></beans>

在粘贴处该xml需要的配置文件:

# datasource
#数据库连接驱动信息
datasource.driver=com.mysql.jdbc.Driver
datasource.url=jdbc:mysql://localhost:3306/ssm?useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull
datasource.username=root
datasource.password=123456# 用来检测连接是否有效的sql
datasource.validationQuery=select 1
# \u5B9A\u4E49\u521D\u59CB\u8FDE\u63A5\u6570
datasource.initialSize=0
# \u5B9A\u4E49\u6700\u5927\u8FDE\u63A5\u6570
datasource.maxActive=20
# \u5B9A\u4E49\u6700\u5C0F\u7A7A\u95F2
datasource.minIdle=1
# \u5B9A\u4E49\u6700\u957F\u7B49\u5F85\u65F6\u95F4
datasource.maxWait=60000
# \u6253\u5F00PSCache\uFF0C\u5E76\u4E14\u6307\u5B9A\u6BCF\u4E2A\u8FDE\u63A5\u4E0APSCache\u7684\u5927\u5C0F
datasource.poolPreparedStatements=true
datasource.maxPoolPreparedStatementPerConnectionSize=33
# \u7533\u8BF7\u8FDE\u63A5\u65F6\u6267\u884CvalidationQuery\u68C0\u6D4B\u8FDE\u63A5\u662F\u5426\u6709\u6548\uFF0C\u505A\u4E86\u8FD9\u4E2A\u914D\u7F6E\u4F1A\u964D\u4F4E\u6027\u80FD\u3002
datasource.testOnBorrow=false
datasource.testOnReturn=false
# \u5EFA\u8BAE\u914D\u7F6E\u4E3Atrue\uFF0C\u4E0D\u5F71\u54CD\u6027\u80FD\uFF0C\u5E76\u4E14\u4FDD\u8BC1\u5B89\u5168\u6027\u3002\u7533\u8BF7\u8FDE\u63A5\u7684\u65F6\u5019\u68C0\u6D4B\uFF0C\u5982\u679C\u7A7A\u95F2\u65F6\u95F4\u5927\u4E8EtimeBetweenEvictionRunsMillis\uFF0C\u6267\u884CvalidationQuery\u68C0\u6D4B\u8FDE\u63A5\u662F\u5426\u6709\u6548\u3002
datasource.testWhileIdle=true
# \u914D\u7F6E\u95F4\u9694\u591A\u4E45\u624D\u8FDB\u884C\u4E00\u6B21\u68C0\u6D4B\uFF0C\u68C0\u6D4B\u9700\u8981\u5173\u95ED\u7684\u7A7A\u95F2\u8FDE\u63A5\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
datasource.timeBetweenEvictionRunsMillis=60000
# \u914D\u7F6E\u4E00\u4E2A\u8FDE\u63A5\u5728\u6C60\u4E2D\u6700\u5C0F\u751F\u5B58\u7684\u65F6\u95F4\uFF0C\u5355\u4F4D\u662F\u6BEB\u79D2
datasource.minEvictableIdleTimeMillis=25200000
# \u6253\u5F00removeAbandoned\u529F\u80FD
datasource.removeAbandoned=true
# \u6570\u636E\u5E93\u8FDE\u63A5\u81EA\u52A8\u56DE\u6536\uFF0C1800\u79D2\uFF0C\u4E5F\u5C31\u662F30\u5206\u949F
datasource.removeAbandonedTimeout=1800
# \u5173\u95EDabanded\u8FDE\u63A5\u65F6\u8F93\u51FA\u9519\u8BEF\u65E5\u5FD7
datasource.logAbandoned=true
# \u76D1\u63A7\u6570\u636E\u5E93
datasource.filters=mergeStat

 

这篇关于spring-datesource.xml配置,spring集成mybatis的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/641085

相关文章

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab