若要在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);
    }
}

当UserDao中配置了Datasource,则会在SimpleJdbcDaoSupport中自动创建一个SimpleJdbcTemplate实例。

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中使用数据库的更多相关文章

  1. [Spring学习笔记 7 ] Spring中的数据库支持 RowMapper,JdbcDaoSupport 和 事务处理Transaction

    1.Spring中的数据库支持 把具有相同功能的代码模板抽取到一个工具类中.2.关于jdbc template的应用 jdbcTemplate模板操作类,把访问jdbc的模板抽取到template中, ...

  2. Spring中的数据库事物管理

    Spring中的数据库事物管理 只要给方法加一个@Transactional注解就可以了 例如:

  3. Spring中获取数据库表主键序列

    在程序开发中,我们经常有写数据库表的操作,数据表中经常带有主键自增序列,如何获取自增序列.spring中提供了相应的类 DataFieldMaxValueIncrementer. DataFieldM ...

  4. spring中的数据库操作类

    例子一: package cn.itcast.service.impl; import java.util.List; import javax.sql.DataSource; import org. ...

  5. Spring中使用JDBC

    Spring中的数据库异常体系 使用JDBC(不使用Spring)的时候,我们需要强制捕获SQLException,否则无法使用JDBC处理任何事情.SQLException表示尝试访问数据库的时候出 ...

  6. 在Spring Boot中使用数据库事务

    我们在前面已经分别介绍了如何在Spring Boot中使用JPA(初识在Spring Boot中使用JPA)以及如何在Spring Boot中输出REST资源(在Spring Boot中输出REST资 ...

  7. spring对数据库的操作、spring中事务管理的介绍与操作

    jdbcTemplate的入门 创建maven工程 此处省略 导入依赖 <!-- https://mvnrepository.com/artifact/org.springframework/s ...

  8. 各种数据库(oracle、mysql、sqlserver等)在Spring中数据源的配置和JDBC驱动包----转

    在开发基于数据库的应用系统时,需要在项目中进行数据源的配置来为数据 库的操作取得数据库连接.配置不同数据库的数据源的方法大体上都是相同的,不同的只是不同数据库的JDBC驱动类和连接URL以及相应的数据 ...

  9. spring中操作mysql数据库

    就是在spring中,对mysql数据库进行增删改查的样例,很easy. 文件结构 maven的pom.xml文件,里面用到的几个很重要的jar包都有 <project xmlns=" ...

随机推荐

  1. crm项目之整体内容(一)

    一.项目背景 YW公司是一家电池供应商,目前由于公司内部的需要,需要做一个CRM项目,需要每一个不同角色的员工登陆系统后处理自己的事情.其流程大致如下: 其项目包括三部分内容: 1.权限分配组件(rb ...

  2. GoF23种设计模式之结构型模式之装饰模式

    一.概述 动态地给一个对象添加一些额外的职责.装饰模式比生成子类更为灵活. 二.适用性 1.在不影响其他对象的情况下,以动态.透明的方式给但个对象添加职责. 2.处理那些可以撤销的职责. 3.当不能采 ...

  3. python数据类型之字符串(str)和其常用方法

    字符串是有序的,不可变的. 下面的例子说明了字符串是不可变的 name = 'alex' name = 'Jack' """ 并没有变,只是给name开启了一块新内存,储 ...

  4. exp分析

    1 from pwn import* 2 3 local =1 4 debug = 1 5 6 if local: 7 p = process('./pwn1') 8 else: 9 p = remo ...

  5. OpenStack, kvm, qemu-kvm以及libvirt之关系

    OpenStack, kvm, qemu-kvm以及libvirt之关系: KVM是最底层的hypervisor,它是用来模拟CPU的运行,它缺少了对network和周边I/O的支持,所以我们是没法直 ...

  6. hdu 4565

    Problem Description A sequence Sn is defined as:Where a, b, n, m are positive integers.┌x┐is the cei ...

  7. meteor 检测运行环境,手机或者桌面

    meteor add mystor:device-detection Meteor.Device.isPhone() https://atmospherejs.com/mystor/device-de ...

  8. python基础学习笔记——字符串方法

    索引和切片: 索引:取出数组s中第3个元素:x=s[2] 切片:用极少的代码将数组元素按需处理的一种方法.切片最少有1个参数,最多有3个参数,演示如下: 我们假设下面所用的数组声明为array=[2, ...

  9. JAVA-基础(十) Swing

    在看到applet和Swing的时候,我想起了winform,以及java beans包中各种所谓的组件的时候,一切都那么似曾相识. Swing是AWT的扩展,它提供了更强大和更灵活的组件集合. 除了 ...

  10. 修改const变量

    看下面的一段代码 ; int * j=(int*)(&i); // 运行正确,j确为i的地址,但 int *j=&i; 编译错误 *j=; //确实改变了i的值 printf(&quo ...