(1)数据源配置

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>
<property name="url" value="jdbc:oracle:thin:@192.168.0.153:1521:OANET"></property>
<property name="username"><value>gd_base</value></property>
<property name="password"><value>11</value></property>
<property name="maxActive"><value>80</value></property>
<property name="minIdle"><value>5</value></property>
<property name="initialSize"><value>10</value></property>
<property name="maxWait"><value>60000</value></property>
<property name="poolPreparedStatements"><value>true</value></property>
<property name="maxOpenPreparedStatements"><value>20</value></property>
<property name="validationQuery"><value>select 1 from dual</value></property>
<property name="testWhileIdle"><value>true</value></property>
<property name="testOnBorrow"><value>false</value></property>
<property name="testOnReturn"><value>false</value></property>
<property name="timeBetweenEvictionRunsMillis"><value>60000</value></property>
<property name="minEvictableIdleTimeMillis"><value>300000</value></property>
<property name="filters"><value>stat,wall</value></property>
<!-- 打开 removeAbandoned 功能 -->
<property name = "removeAbandoned" value = "true" />
<!-- 1800 秒,也就是 30 分钟 -->
<property name = "removeAbandonedTimeout" value ="1800" />
<!-- 关闭 abanded 连接时输出错误日志 -->
<property name = "logAbandoned" value = "true" />
</bean>

配置参数的解释:

配置参数 参数含义
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" destroy-method="close">

destroy-method="close"的作用是当数据库连接不使用的时候,就把该连接重新放到数据池中,方便下次使用调用.(数据库连接关闭)
class="com.alibaba.druid.pool.DruidDataSource"
DRUID连接池,DRUID是阿里巴巴开源平台上一个数据库连接池实现,它结合了C3P0、DBCP、PROXOOL等DB池的优点,同时加入了日志监控,
可以很好的监控DB池连接和SQL的执行情况,可以说是针对监控而生的DB连接池.和其它连接池一样DRUID的DataSource类为:com.alibaba.druid.pool.DruidDataSource

<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"></property>

使用的JDBC驱动的完整有效的java 类名
连接数据库要加载驱动,oracle.jdbc.driver.OracleDriver 可以认为是驱动类的名字,前面oracle.jdbc.driver是包名,类名是OracleDriver

<property name="url" value="jdbc:oracle:thin:@192.168.0.153:1521:OANET"></property>

传递给JDBC驱动的用于建立连接的URL
jdbc:oracle:thin:@192.168.0.153:1521:OANET
jdbc:表示采用jdbc方式连接数据库
oracle:表示连接的是oracle数据库
thin:表示连接时采用thin模式(oracle中有两种模式,分别是oci和thin)
jdbc:oralce:thin:是一个jni方式的命名
@192.168.0.153表示地址
1521和orcl表示端口和数据库名

oracle的jdbc连接方式:oci和thin
oci和thin是Oracle提供的两套Java访问Oracle数据库方式。
thin是一种瘦客户端的连接方式,即采用这种连接方式不需要安装oracle客户端,只要求classpath中包含jdbc驱动的jar包就行。thin就是纯粹用Java写的ORACLE数据库访问接口。
oci是一种胖客户端的连接方式,即采用这种连接方式需要安装oracle客户端。oci是Oracle Call Interface的首字母缩写,是ORACLE公司提供了访问接口,就是使用Java来调用本机的Oracle客户端,然后再访问数据库,优点是速度快,但是需要安装和配置数据库。

<property name="username"><value>gd_base</value></property> 传递给JDBC驱动的用于建立连接的用户名
<property name="password"><value>11</value></property> 传递给JDBC驱动的用于建立连接的密码
<property name="maxActive"><value>80</value></property> 最大连接数量
<property name="minIdle"><value>5</value></property> 最小空闲连接数量
<property name="initialSize"><value>10</value></property> 初始化连接数量
<property name="maxWait"><value>60000</value></property> 超时等待时间以毫秒为单位
<property name="poolPreparedStatements"><value>true</value></property> 是否缓存preparedStatement,也就是PSCache。PSCache对支持游标的数据库性能提升巨大,比如说oracle。在mysql下建议关闭。
<property name="maxOpenPreparedStatements"><value>20</value></property> statement池能够同时分配的打开的statements的最大数量, 如果设置为0表示不限制
<property name="validationQuery"><value>select 1 from dual</value></property>

用来检测连接是否有效的sql,要求是一个查询语句。如果validationQuery为null,testOnBorrow、testOnReturn、testWhileIdle都不会其作用。
如果是MySql的话就用<property name="validationQuery"><value>select *</value></property>

<property name="testWhileIdle"><value>true</value></property> 建议配置为true,不影响性能,并且保证安全性。申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,执行validationQuery检测连接是否有效。
<property name="testOnBorrow"><value>false</value></property> 申请连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能。
<property name="testOnReturn"><value>false</value></property> 归还连接时执行validationQuery检测连接是否有效,做了这个配置会降低性能
<property name="timeBetweenEvictionRunsMillis"><value>60000</value></property> 在空闲连接回收器线程运行期间休眠的时间值,以毫秒为单位
<property name="minEvictableIdleTimeMillis"><value>300000</value></property> 连接在池中保持空闲而不被空闲连接回收器线程
<property name="filters"><value>stat,wall</value></property> 属性类型是字符串,通过别名的方式配置扩展插件,常用的插件有:监控统计用的filter:stat 日志用的filter:log4j 防御sql注入的filter:wall
<property name = "removeAbandoned" value = "true" />  removeAbandoned: 是否自动回收超时连接
<property name = "removeAbandonedTimeout" value ="1800" /> removeAbandonedTimeout: 超时时间(以秒数为单位)
<property name = "logAbandoned" value = "true" />  连接被泄露时是否打印 

(2)Spring为我们提供了SqlMapClientDaoSupportExtend支持类,所有DAO继承这个类,就会自动获得JdbcTemplate(前提是注入dataSource)

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource" />
</bean>

JdbcTemplate主要提供下列方法:

  1、execute方法:可以用于执行任何SQL语句,一般用于执行DDL语句;

  2、update方法及batchUpdate方法:update方法用于执行新增、修改、删除等语句;batchUpdate方法用于执行批处理相关语句;

  3、query方法及queryForXXX方法:用于执行查询相关语句;

  4、call方法:用于执行存储过程、函数相关语句。

Spring配置常识的更多相关文章

  1. Spring配置c3p0数据源时出错报:java.lang.NoClassDefFoundError: com/mchange/v2/ser/Indirector

    今天在使用Spring配置c3p0数据源时,使用的数据库是mysql,服务器是tomcat,运行时报了一个 java.lang.NoClassDefFoundError: com/mchange/v2 ...

  2. Spring配置汇总

    现在主流的JavaWeb应用几乎都会用到Spring,以下是Spring的配置,以及结合Web的SpringMVC配置的汇总. jar包的引入 与Web项目集成 Spring配置文件 SpringMV ...

  3. spring配置属性的两种方式

    spring配置属性有两种方式,第一种方式通过context命名空间中的property-placeholder标签 <context:property-placeholder location ...

  4. 解决eclipse spring配置报错:cvc-elt.1: Cannot find the declaration of element

    解决eclipse spring配置报错:cvc-elt.1: Cannot find the declaration of element 'beans'.Referenced file conta ...

  5. spring配置详解

    1.前言 公司老项目的后台,均是基于spring框架搭建,其中还用到了log4j.jar等开源架包.在新项目中,则是spring和hibernate框架均有使用,利用了hibernate框架,来实现持 ...

  6. memcached 学习 1—— memcached+spring配置

    memcached 学习目录: memcached 学习 1—— memcached+spring配置 这几天自己搭建项目环境,解决问题如下: 有关常见的配置这里没有列出,中间遇到的搭建问题比较顺利g ...

  7. 解决spring配置中的bean类型的问题:BeanNotOfRequiredTypeException

    解决spring配置中的bean类型的问题:BeanNotOfRequiredTypeException这个问题出现的原因:一般在使用annotation的方式注入spring的bean 出现的,具体 ...

  8. spring配置中,properties文件以及xml文件配置问题

    spring方便我们的项目快速搭建,功能强大,自然也会是体系复杂! 这里说下配置文件properties管理的问题. 一些不涉及到代码逻辑,仅仅只是配置数据,可以放在xxxx.properties文件 ...

  9. IntelliJ IDEA通过Spring配置连接MySQL数据库

    先从菜单View→Tool Windows→Database打开数据库工具窗口,如下图所示: 点击Database工具窗口左上角添加按钮"+",选择Import from sour ...

随机推荐

  1. Linux 性能分析工具汇总合集

    出于对Linux操作系统的兴趣,以及对底层知识的强烈欲望,因此整理了这篇文章.本文也可以作为检验基础知识的指标,另外文章涵盖了一个系统的方方面面.如果没有完善的计算机系统知识,网络知识和操作系统知识, ...

  2. web安全之攻击

    转自 知乎https://www.zhihu.com/question/22953267 作者:潘良虎链接:https://www.zhihu.com/question/22953267/answer ...

  3. 蒟蒻qxt的sd'日常

    emm... 今天刷了一道水题 居然 死循环了 真的是水题啊 顿时自闭 (救救孩子吧) 结果 bug是 我把for循环中的i的值改变了 使得i的值一直都不会达到他的边界值 于是就死循环了 所以 要用到 ...

  4. 1226 快速幂 取余运算 洛谷luogu

    还记得 前段时间学习二进制快速幂有多崩溃 当然这次方法略有不同 居然轻轻松松的 题目描述 输入b,p,k的值,求b^p mod k的值.其中b,p,k*k为长整型数. 输入输出格式 输入格式: 三个整 ...

  5. 项目Alpha冲刺 2

    作业描述 课程: 软件工程1916|W(福州大学) 作业要求: 项目Alpha冲刺(团队) 团队名称: 火鸡堂 作业目标: 进行github实战训练,锻炼团队合作能力 1.团队信息 队名:火鸡堂 队员 ...

  6. django_redis作为 session backend 使用配置

    Django 默认可以使用任何 cache backend 作为 session backend, 将 django-redis 作为 session 储存后端不用安装任何额外的 backend # ...

  7. 【Codeforces 1110D】Jongmah

    Codeforces 1110 D 题意:给\(n\)个麻将,每个麻将上有一个\(1..m\)的整数\(a_i\). 现在要将这些麻将们分成一个一个三元组,有两种情况: \([i-1,i,i+1]\) ...

  8. MySQL(十二)游标和触发器

    一.游标 定义:存储在MySQL服务器上的数据库查询,是一种被select语句检索出来的结果集. 作用:方便在检索出来的结果集中前进或后退一行或多行. 游标主要用于交互式应用:MySQL中的游标只能用 ...

  9. spring-cloud-starter-feign 等jar无法reimport的解决方案

    <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> &l ...

  10. Java原子类AtomicInteger实现原理的一点总结

    java原子类不多,包路径位于:java.util.concurrent.atomic,大致有如下的类: java.util.concurrent.atomic.AtomicBoolean java. ...