Spring-JDBC配置
以C3P0连接池为例:由于C3P0是第三方,我们无法使用注解将其定义为bean,因此需要在applicationContext.xml中配置:
<!-- 导入配置文件 -->
<context:property-placeholder location="classpath:dataSource.properties"/>
<aop:aspectj-autoproxy proxy-target-class="true"/>
<bean id="dataSourceLocal" name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<!-- 指定连接数据库的驱动-->
<property name="driverClass" value="${jdbc.driverClassName}"/>
<!-- 指定连接数据库的URL-->
<property name="jdbcUrl" value="${jdbc.url}"/>
<!-- 指定连接数据库的用户名-->
<property name="user" value="${jdbc.username}"/>
<!-- 指定连接数据库的密码-->
<property name="password" value="${jdbc.password}"/>
<!-- 指定连接池中保留的最大连接数. Default:15-->
<property name="maxPoolSize" value="${jdbc.maxPoolSize}"/>
<!-- 指定连接池中保留的最小连接数-->
<property name="minPoolSize" value="${jdbc.minPoolSize}"/>
<!-- 指定连接池的初始化连接数 取值应在minPoolSize 与 maxPoolSize 之间.Default:3-->
<property name="initialPoolSize" value="${jdbc.initialPoolSize}"/>
<!-- 最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。 Default:0-->
<property name="maxIdleTime" value="${jdbc.maxIdleTime}"/>
<!-- 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数. Default:3-->
<property name="acquireIncrement" value="${jdbc.acquireIncrement}"/>
<!-- JDBC的标准,用以控制数据源内加载的PreparedStatements数量。
但由于预缓存的statements属于单个connection而不是整个连接池所以设置这个参数需要考虑到多方面的因数.如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default:0-->
<property name="maxStatements" value="${jdbc.maxStatements}"/>
<!-- 每60秒检查所有连接池中的空闲连接.Default:0 -->
<property name="idleConnectionTestPeriod" value="${jdbc.idleConnectionTestPeriod}"/>
</bean>
c3p0连接池配置
可以看到,连接配置中引用了<context:property-placeholder location="classpath:dataSource.properties"/>标签,这是说从外部配置文件中读取数据库相关的数据,用${}表达式可以读取,因此,我们需要同时配置dataSource.properties文件,内容如下:
jdbc.driverClassName=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=scott
jdbc.password=orcl
jdbc.initialPoolSize=20
jdbc.maxPoolSize=100
jdbc.minPoolSize=10
jdbc.maxIdleTime=600
jdbc.acquireIncrement=5
jdbc.maxStatements=5
jdbc.idleConnectionTestPeriod=60
dataSource
只要保证配置文件正确,数据库的连接配置也就完成了,接下来需要配置JDBCTemplate,仍然是在applicationContext.xml中配置:
<!-- 配置jdbcTemplate -->
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSourceLocal"></property>
</bean>
JDBCTemplate
JDBCTemplate类中,只有一个参数,那就是dataSource,因此需要注入上面的dateSource。
接下来以Oracle中Scott用户下的dept表为例测试:
private ApplicationContext ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
private JdbcTemplate jt=(JdbcTemplate) ctx.getBean("jdbcTemplate");
取得bean-JDBCTemplate
@Test
public void updateTest(){
String sqlUpdate="update emp set ename=? where empno=?";
jt.update(sqlUpdate,"SMITH",7369);
}
单条增删改测试
可以看到,此处在sql语句中使用了?作为占位符,在JDBCTemplate的update方法中一一对应定义即可。
另外,JDBCTemplate同时支持批量操作,代码如下:
@Test
public void testBatchUpdate(){
//批量修改
String[] s=new String[]{"update emp set ename='SMITH1' where empno=7369","update emp set ename='SMITH' where empno=7369"};
jt.batchUpdate(s);
//批量添加
List<Object[]> addList = new ArrayList<Object[]>();
addList.add(new Object[]{52,"AA","SHANGHAI"});
addList.add(new Object[]{62,"BB","BEIJING"});
addList.add(new Object[]{72,"CC","XI'AN"});
addList.add(new Object[]{82,"DD","HANGZHOU"});
jt.batchUpdate("insert into scott.dept values (?,?,?)",addList);
//批量删除
List<Object[]> delList = new ArrayList<Object[]>();
delList.add(new Integer[]{40});
jt.batchUpdate("delete dept where deptno>?",delList);
}
批量增删改
批量操作需要用到batchUpdate方法,其重载形式如下:

我们使用了第一和第三种方法就够用了。
查询分为单条数据查询和多条数据查询,JDBCTemplate支持使用RowMapper类将其对应到相应的实体类,如果是单条数据,可使用queryForObject方法:
@Test
public void testQueryForObject(){
String sql="select deptno,dname,loc from dept where deptno=?";
RowMapper<Dept> rm=new BeanPropertyRowMapper<Dept>(Dept.class);
Dept d=jt.queryForObject(sql,rm,20);
System.err.println(d);
}
查询单条数据
如果是多条数据,可以用query方法:
@Test
public void testQueryForList(){
String sql="select * from dept where deptno>?";
RowMapper<Dept> re=new BeanPropertyRowMapper<Dept>(Dept.class);
List<Dept> dept=jt.query(sql, re,20);
System.out.println(dept);
}
查询多条数据
另外,也支持统计查询和单列查询:
@Test
public void testQueryColumnOrCount(){
//获取统计信息
String sql="select count(empno) from emp";
Long l=jt.queryForObject(sql, Long.class);
System.err.println(l);
//获取单列信息
String sql4Date="select hiredate from emp";
RowMapper<Date> re=new BeanPropertyRowMapper<Date>(Date.class);
List<Date> d=jt.query(sql4Date, re);
System.err.println(d);
}
统计查询和单列查询
从上面的例子中可以看到,参数都是通过?占位符顺序一一对应传递参数的,如果参数位置变动,那么JDBC操作需要同时变更,不安全且工作量大,因此Spring同时提供了NamedParameterJDBCTemplate具名参数:SQL 按名称(以冒号开头)而不是按位置进行指定.。
优势:具名参数更易于维护, 也提升了可读性.
与JDBCTemplate一样,需要在XML中配置:
<!-- 配置NamedParameterJDBCTemplate -->
<bean id="namedParameterJDBCTemplate" class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate">
<constructor-arg><ref bean="dataSourceLocal"/></constructor-arg>
</bean>
NamedParameterJDBCTemplate配置
用法:
在 SQL 语句中使用具名参数时, 可以在一个 Map 中提供参数值, 参数名为键
也可以使用 SqlParameterSource 参数
批量更新时可以提供 Map 或 SqlParameterSource 的数组
代码如下:
/**
* NamedParameterJDBCTemplate用法测试,以update为例
*/
@Test
public void testNamedParameterJDBCTemplate(){
String sql="insert into dept values (:deptno,:dname,:loc)";//此处参数是可以自由命名的
Map<String, Object> map=new HashMap<String, Object>();
map.put("deptno", 94);
map.put("dname", "管理部");
map.put("loc", "金华");
npjt.update(sql, map);
}
/**
* 使用SqlParameterSource类与实体类对应,此时参数命名需与实体类属性名对应
* SqlParameterSource sps = new BeanPropertySqlParameterSource(对象)
*/
@Test
public void testNamedParameterJDBCTemplateByEntity(){
String sql="insert into dept values (:deptno,:dname,:loc)";//此处参数命名需与实体类属性名相同
SqlParameterSource sps=new BeanPropertySqlParameterSource(new Dept(88, "业务部", "北京"));
npjt.update(sql, sps);
}
具名参数测试
高级用法参考:Spring框架笔记(二十五)——NamedParameterJdbcTemplate与具名参数
总结:JDBCTemplate很强大,但毕竟不是ORM框架,比如,并不支持级联操作。
Spring-JDBC配置的更多相关文章
- Spring JDBC配置数据源
在本系列教程中,使用的的是MySQL数据库,并创建一个数据库实例:test,在这个数据库实例:test中创建一个表student.如果您使用任何其他数据库,则可以相应地更改DDL和SQL查询,这问题不 ...
- spring jdbc 配置数据源连接数据库
概述 在XML配置数据源,并将数据源注册到JDBC模板 JDBC模板关联业务增删改查 在XML配置数据源 <?xml version="1.0" encoding=" ...
- Spring JDBC主从数据库配置
通过昨天学习的自定义配置注释的知识,探索了解一下web主从数据库的配置: 背景:主从数据库:主要是数据上的读写分离: 数据库的读写分离的好处? 1. 将读操作和写操作分离到不同的数据库上,避免主服务器 ...
- spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置
spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...
- Spring JDBC主从数据库访问配置
通过昨天学习的自定义配置注释的知识,探索了解一下web主从数据库的配置: 背景:主从数据库:主要是数据上的读写分离: 数据库的读写分离的好处? 1. 将读操作和写操作分离到不同的数据库上,避免主服务器 ...
- 在Spring中配置jdbc为什么不能用${username}问题
楼主在spring中配置jdbc时,引用的是dbcp.jar包,在dataSource.properties配置文件中,有mysql用户名,楼主自然的选择了使用username,密码是root, 然后 ...
- 【Spring】Spring的数据库开发 - 1、Spring JDBC的配置和Spring JdbcTemplate的解析
Spring JDBC 文章目录 Spring JDBC Spring JdbcTemplate的解析 Spring JDBC的配置 简单记录-Java EE企业级应用开发教程(Spring+Spri ...
- Spring Boot -- 配置切换指南
一般在一个项目中,总是会有好多个环境.比如: 开发环境 -> 测试环境 -> 预发布环境 -> 生产环境 每个环境上的配置文件总是不一样的,甚至开发环境中每个开发者的环境可能也会有一 ...
- spring 定时任务配置
1.(易)如何在spring中配置定时任务? spring的定时任务配置分为三个步骤: 1.定义任务 2.任务执行策略配置 3.启动任务 (程序中一般我们都是到过写的,直观些) 1.定义任务 < ...
- Spring JDBC实现查询
1 db.properties jdbc.user=root jdbc.password=920614 jdbc.driverClass=com.mysql.jdbc.Driver jdbc.jdbc ...
随机推荐
- 【Asp.net之旅】--因自己定义控件注冊而引发的思考
前言 近期在开发远洋的SOA系统平台,开发使用的是.NET平台.对于Asp.net并不困难,但该系统的开发并非全然依靠Asp.net.而是自身封装好的框架.这套框架是远洋地产购买的微软的开发平台,项目 ...
- jQuery判断复选框是否勾选
一个功能复选框勾选时给input表单赋值,复选框取消时将表单值清除. 功能:复选框勾选时给input表单赋值,复选框取消时将表单值清除. 实现源码:cyfID为复选框的id $("#cyfI ...
- Django:Django Rest Framework
Django Rest Framework 一. 什么是RESTful REST与技术无关,代表的是一种软件架构风格,REST是Representational State Transfer的简称 ...
- 基于jQuery+ashx+.net实现三级栏目联动操作
父级ID可以为空以两个编号为一级 可以添加到第四级 table 字段有ID. name .parentNode. childNode等基本属性 selecet parentNode ,len(c ...
- cocos2d-x 数据存储
这一章中,我们从一个小小的金币数入手,讨论了数据持久化的话题.我们尽量使用引擎提供的数据存储方法,以最大可能地适应跨平台需求.这里介绍的存储方法本质上都是基于 XML 的,对于 1 MB 以下的存储规 ...
- HTML的级联Select
系统开发中,经常遇到级联Select的状况,而级联的Select Option数据一般记录于DB,如果每次都重新写一套级联Select,工作将是繁琐滴... 一般来说,写一套级联的Select的几个步 ...
- 解决python2.7 UnicodeDecodeError和UnicodeEncodeError问题
最近在项目中,读取上传的csv文件,并写入时,会报编码问题, with open(origin_file_path, mode='wb')as f: for chunk in file_obj: f. ...
- [小技巧]Mac上chrome打开触控板双指前进后退功能
Orz,本以为是默认开启的,结果发现并不是,从系统里找了半天发现没找到-就搜了一下,原来可以命令开启来 defaults write com.google.Chrome AppleEnableSwip ...
- mvn项目中的pom文件提示Error parsing lifecycle processing instructions解决
清空.m2/repository下的所有依赖文件,重新下载即可解决该问题. 如果本地用户下没有.m2/repository 目录,找到如下mvn 指定的repository,进去之后清空所有文件.
- Linux下crontab内环境变量与Shell环境变量的关系【转】
crontab,总是不会缺省的从用户profile文件中读取环境变量参数 经常导致在手工执行某个脚本时是成功的,但是到crontab中试图执行时就会报错. 解决办法如下: 方法一:在shell文件中获 ...