在spring中使用数据库
若要在spring中使用数据库,首先需要配置数据源。
1、使用数据源连接池,可以使用DBCP(Data Base Connection Pooling)
<bean id="datasource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="username">xx</property>
<property name="password">xx</property>
<property name="url">xx</property>
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
</bean>
2、使用spring 自带的基于JDBC驱动的数据源。spring提供了两种数据源对象:
DriverManagerDataSource:在每个连接请求时都会返回一个新建的连接。
SingleConnectionDataSource:在每个连接请求时都会返回同一个连接。可看做只有一个连接。
这两个数据源的配置与BasicDataSource配置类似,唯一的区别是BasicDataSource提供连接池功能。
3、使用JDBC模板:使用SimpleJdbcTemplate访问数据
需要在spring上下文中配置SimpleJdbcTemplate Bean:如:
<bean id="simpleTemplate" class="org.springframework.jdbc.core.simple.SimpleJdbcTemplate">
<constructor-arg ref="datasource"></constructor-arg>
</bean>
在Dao层使用模板访问数据时:
@Component("userDao")
public class UserDaoImpl implements UserDao {
private static final String INSERT_SQL = "insert into user(username,password) values(:username,:passwprd)";
private SimpleJdbcTemplate simpleTemplate;
public void addUser(Monkey monkey) {
Map<String,String> params = new HashMap<String,String>();
params.put("username", monkey.getName());
params.put("password", monkey.getPassword());
simpleTemplate.update(INSERT_SQL, params);
}
@Autowired
public void setSimpleTemplate(SimpleJdbcTemplate simpleTemplate) {
this.simpleTemplate = simpleTemplate;
} }
4、使用spring的Dao 支持类:SimpleJdbcDaoSupport
@Component("userDao")
public class UserDaoImpl extends SimpleJdbcDaoSupport implements UserDao {
private static final String INSERT_SQL = "insert into user(username,password) values(:username,:passwprd)";
@Autowired
public void setDatasource(DataSource datasource) {
this.setDatasource(datasource);
}
public void addUser(Monkey monkey) {
Map<String,String> params = new HashMap<String,String>();
params.put("username", monkey.getName());
params.put("password", monkey.getPassword());
this.getJdbcTemplate().update(INSERT_SQL, params);
}
}
JdbcDaoSupport中的一个方法:
/**
* Set the JDBC DataSource to be used by this DAO.
*/
public final void setDataSource(DataSource dataSource) {
if (this.jdbcTemplate == null || dataSource != this.jdbcTemplate.getDataSource()) {
this.jdbcTemplate = createJdbcTemplate(dataSource);
initTemplateConfig();
}
}
在spring中使用数据库的更多相关文章
- [Spring学习笔记 7 ] Spring中的数据库支持 RowMapper,JdbcDaoSupport 和 事务处理Transaction
1.Spring中的数据库支持 把具有相同功能的代码模板抽取到一个工具类中.2.关于jdbc template的应用 jdbcTemplate模板操作类,把访问jdbc的模板抽取到template中, ...
- Spring中的数据库事物管理
Spring中的数据库事物管理 只要给方法加一个@Transactional注解就可以了 例如:
- Spring中获取数据库表主键序列
在程序开发中,我们经常有写数据库表的操作,数据表中经常带有主键自增序列,如何获取自增序列.spring中提供了相应的类 DataFieldMaxValueIncrementer. DataFieldM ...
- spring中的数据库操作类
例子一: package cn.itcast.service.impl; import java.util.List; import javax.sql.DataSource; import org. ...
- Spring中使用JDBC
Spring中的数据库异常体系 使用JDBC(不使用Spring)的时候,我们需要强制捕获SQLException,否则无法使用JDBC处理任何事情.SQLException表示尝试访问数据库的时候出 ...
- 在Spring Boot中使用数据库事务
我们在前面已经分别介绍了如何在Spring Boot中使用JPA(初识在Spring Boot中使用JPA)以及如何在Spring Boot中输出REST资源(在Spring Boot中输出REST资 ...
- spring对数据库的操作、spring中事务管理的介绍与操作
jdbcTemplate的入门 创建maven工程 此处省略 导入依赖 <!-- https://mvnrepository.com/artifact/org.springframework/s ...
- 各种数据库(oracle、mysql、sqlserver等)在Spring中数据源的配置和JDBC驱动包----转
在开发基于数据库的应用系统时,需要在项目中进行数据源的配置来为数据 库的操作取得数据库连接.配置不同数据库的数据源的方法大体上都是相同的,不同的只是不同数据库的JDBC驱动类和连接URL以及相应的数据 ...
- spring中操作mysql数据库
就是在spring中,对mysql数据库进行增删改查的样例,很easy. 文件结构 maven的pom.xml文件,里面用到的几个很重要的jar包都有 <project xmlns=" ...
随机推荐
- python3 完全平方数(循环)
题目 一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少? 代码: for i in range(1,85): if 168 % i == 0: j = 168 ...
- 01 Django基础知识
相关概念 软件框架 一个公司是由公司中的各部部门来组成的,每一个部门拥有特定的职能,部门与部门之间通过相互的配合来完成让公司运转起来. 一个软件框架是由其中各个软件模块组成的,每一个模块都有特定的功能 ...
- 如何在微信中发送"相册"文件时有选择性地显示视频文件
相信很多微信用户在使用微信给朋友,同事发送相册中的文件时,微信会显示你手机中的视频文件,这样很不方便. 如果要完全不显示视频文件: 随便在手机中建立一个文件夹,名字叫 ".nomedia&q ...
- Linux异常体系之vector_stub宏解析
ARM-Linux汇编的宏定义语法说明如下: 使用注意: 1.宏定义以.macro开始,以.endm结束 2.可带参数,参数可有默认值 3.直接使用参数的名字\arg vector_stub宏的功能: ...
- Linux学习-Linux 主机上的用户讯息传递
查询使用者: w, who, last, lastlog 如果你想要知道目前已登入在系统上面的用户呢?可以透过 w 或 who 来查询喔!如下范例所示: [root@study ~]# w 01:49 ...
- 线程中更新ui方法汇总
一.为何写作此文 你是不是经常看到很多书籍中说:不能在子线程中操作ui,不然会报错.你是不是也遇到了如下的疑惑(见下面的代码): @Override protected void onCreate ...
- Python 综合应用小项目一
数据库报错重连机制 利用异常捕获来获取mysql断开的报错,然后再重连 import MySQLdb as mysql class DB: def __init__(self,host,user,pa ...
- TensorFlow——热身运动:简单的线性回归
过程: 先用numpy建立100个数据点,再用梯度下滑工具来拟合,得到完美的回归线. # _*_coding:utf-8_*_ import tensorflow as tf import numpy ...
- webstorm自带debugger服务器
打开webstorm->settings->Build,Execution,Deployment->Debugger->把端口Port改成8089或者其他80端口,按确定就可以 ...
- 用js判断浏览器类型及设备
<!DOCTYPE html> <html> <head> <title>JS判断是什么设备是什么浏览器</title> <meta ...