`
buynow96
  • 浏览: 3789 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

spring 使用dataSource、JdbcTemplate简化数据库操作

阅读更多

spring 使用dataSourceJdbcTemplate简化数据库操作

 

我们在Java代码中使用jdbc中,总是会有很多重复的代码区,可能真正操作数据库的代码只占了20%。作为一名程序员应该简化这些需要重复的部分很着重于核心的数据库操作部分。

Spring提供的jdbcTemplate很好的帮我们解决了问题,让我们真正的只用关心编写操作数据库的代码。

在spring中使用数据源是很好的方案,第一步我们来配置一个c3p0数据源在spring 的配置中:

<!--从类路径下导入jdbc.properties 文件 配置信息放置于其中-->

<util:properties id="jdbc" location="classpath:jdbc.properties"/>

<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">

    <property name="jdbcUrl" value="#{jdbc.url}" />
    <property name="driverClass" value="#{jdbc.driverClassName}" />
    <property name="user" value="#{jdbc.username}" />
    <property name="password" value="#{jdbc.password}" />
    <!--连接池中保留的最大连接数。Default: 15 -->
    <property name="maxPoolSize" value="100" />
    <!--连接池中保留的最小连接数。-->
    <property name="minPoolSize" value="1" />
    <!--初始化时获取的连接数,取值应在minPoolSizemaxPoolSize之间。Default: 3 -->
    <property name="initialPoolSize" value="10" />
    <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->
    <property name="maxIdleTime" value="30" />
    <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->
    <property name="acquireIncrement" value="5" />
    <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements
      属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。
      如果maxStatementsmaxStatementsPerConnection均为0,则缓存被关闭。Default: 0-->
    <property name="maxStatements" value="0" />
    <!--60秒检查所有连接池中的空闲连接。Default: 0 -->
    <property name="idleConnectionTestPeriod" value="60" />
    <!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->
    <property name="acquireRetryAttempts" value="30" />
    <!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效
      保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试
      获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->
    <property name="breakAfterAcquireFailure" value="true" />
    <!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的
      时候都将校验其有效性。建议使用idleConnectionTestPeriodautomaticTestTable
      等方法来提升连接测试的性能。Default: false -->
    <property name="testConnectionOnCheckout"  value="false" />
</bean>

 

我们使用了Spring 提供的<util:properties/>jdbc配置文件导入为一个bean 并使用#{...}的方式导入

Jdbc.properties文件提供jdbc连接信息:

url=jdbc:MySQL:///testdb
driverClassName=com.mysql.jdbc.Driver
username=root
password=20080808

接下来就是最重要的一步了,配置好jdbc模板(jdbcTemplate)

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <constructor-arg ref="dataSource"></constructor-arg>
</bean>

将数据源以构造注入的方式注入

这样我们就可以在代码中通过getBean的方式获取了。


    JdbcTemplate template = beanContext.getBean("jdbcTemplate", JdbcTemplate.class);
    Persion persion = (Persion) template.queryForObject("select * from t_persion where name=?"new Object[]{"zhao"},
            new RowMapper<Persion>() {
        @Override
        public Persion mapRow(ResultSet rs, int rowNum) throws SQLException {
            Persion p = new Persion();
            p.setName(rs.getString("name"));
            p.setAge(rs.getInt("age"));
            p.setId(rs.getInt("id"));
            return p;
        }
    });
    System.out.println(persion);

对于jdbcTemplate的操作api 官方文档又详细的解释

jdbcTemplate是线程安全的

我们可以直接将Dao作为一个bean jdbcTemplate注入其中

<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <constructor-arg ref="dataSource"></constructor-arg>
</bean>
<bean id="persionDao" class="cn.zhaoyuening.dao.PersionDao">
    <property name="jdbcTemplate" ref="jdbcTemplate"/>
</bean>

 

persionDao代码:

public class PersionDao {
    private JdbcTemplate jdbcTemplate;

    public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
        this.jdbcTemplate = jdbcTemplate;
    }

    public void addPersion(Persion persion){...}
    public void removePersionById(int id){...}
    public Persion getPersionByName(String name) {
        Persion persion = (Persion) jdbcTemplate.queryForObject("select * from t_persion where name=?"new Object[]{"zhao"},
                new RowMapper<Persion>() {
                    @Override
                    public Persion mapRow(ResultSet rs, int rowNum) throws SQLException {
                        Persion p = new Persion();
                        p.setName(rs.getString(name));
                        p.setAge(rs.getInt("age"));
                        p.setId(rs.getInt("id"));
                        return p;
                    }
                });
        return persion;
    }
}

0
2
分享到:
评论

相关推荐

    简单介绍如何使用Spring Boot使用JdbcTemplate与MySQL进行数据库操作

    在本文中,我们将深入探讨如何使用Spring Boot集成JdbcTemplate与MySQL数据库进行数据操作。Spring Boot以其简化配置和快速启动的特点,已经成为Java开发者的首选框架。而JdbcTemplate是Spring框架的一部分,它提供...

    详解在spring中使用JdbcTemplate操作数据库的几种方式

    在Spring框架中,JdbcTemplate是用于简化数据库操作的工具,它提供了一种声明式的方式处理SQL,降低了数据库访问的复杂性。本篇文章将详细介绍如何在Spring中使用JdbcTemplate进行数据库操作,包括设置依赖、创建...

    使用JdbcTemplate操作数据库.zip

    在Spring Boot框架中,JdbcTemplate是一个非常重要的组件,它提供了简化数据库操作的API,使得开发者可以更加方便地执行SQL语句。本项目旨在利用JdbcTemplate进行数据库操作,从而实现一些常见的数据库交互功能。 ...

    Spring Boot多数据源(JdbcTemplate)配置与使用

    `JdbcTemplate`是Spring框架提供的一个用于简化数据库操作的工具,它使得数据库访问更为简洁且不易出错。在本教程中,我们将深入探讨如何在Spring Boot项目中配置和使用多数据源以及JdbcTemplate。 首先,让我们...

    使用spring jdbc template简化jdbc数据库操作实例代码

    Spring JDBC Template是Spring框架的一部分,它为Java数据库连接(JDBC)提供了一种抽象层,目的是简化数据库操作,同时保留了JDBC的灵活性。在实际开发中,它可以帮助我们避免编写大量的样板代码,如手动打开和关闭...

    Spring boot 使用JdbcTemplate访问数据库

    在 Spring Boot 中使用 JdbcTemplate 访问数据库,是一种常见且简便的方式,特别适合那些需要对数据库进行基础操作的应用。 JdbcTemplate 是 Spring Framework 提供的一个模板类,它对 JDBC API 进行了封装,使得...

    SpringJDBC.rar_SpringJDBC_jdbctemplate_jdbctemplate spring

    在Java的Spring框架中,Spring JDBC(Java Database Connectivity)是一个重要的模块,用于简化数据库操作。Spring JDBC通过提供JdbcTemplate和SimpleJdbcTemplate等工具类,帮助开发者以更安全、更易于管理的方式与...

    spring的jdbcTemplate小案例

    JdbcTemplate是Spring提供的一种数据库操作工具,它简化了数据库访问,使开发者能够编写出更健壮、更易于维护的代码,避免了手动处理JDBC连接、预编译SQL语句等繁琐任务。 首先,我们来理解一下JdbcTemplate的基本...

    spring-jdbcTemplate实例工程

    总的来说,Spring JdbcTemplate是Spring框架中处理数据库操作的重要工具,它通过简化JDBC API,提升了开发效率和代码质量。在实际项目中,结合Spring的其他组件,可以构建出稳定、高效的数据访问层。这个实例工程为...

    spring中dataSource的配置以及配合IOC的使用

    Spring提供了`JdbcTemplate`和`NamedParameterJdbcTemplate`,它们是简化数据库操作的工具类。它们通过`DataSource`获取连接,并在完成后释放资源。在配置了`DataSource`后,我们可以自动注入这两个工具类进行数据库...

    SpringJdbcTemplate封装工具类

    SpringJdbcTemplate是Spring框架中用于简化Java数据库访问的工具,它是Spring JDBC模块的核心。这个封装工具类的出现是为了提供一种更简洁、易于使用的接口来执行SQL操作,减轻开发者处理数据库连接、事务管理以及...

    Spring-JdbcTemplate

    为了解决这些问题,Spring引入了JdbcTemplate,它通过提供一系列预定义的方法来简化数据库操作。例如,对于一个简单的SELECT查询,使用JdbcTemplate可以写出更为简洁的代码: ```java String sql = "select * from ...

    JdbcTemplate操作数据库实现添加功能

    在Java开发中,Spring框架提供了一个强大的数据访问抽象层,其中`JdbcTemplate`是用于简化数据库操作的重要组件。本文将详细讲解如何利用`JdbcTemplate`实现数据库的添加(INSERT)功能,以及它在实际开发中的应用和...

    spring框架 jdbcTemplate

    JdbcTemplate是Spring框架中的一个核心组件,主要用于简化数据库操作。它通过提供一系列的模板方法,如query()、update()等,来处理SQL语句的执行,同时处理异常、事务管理和结果集映射,使得数据库操作变得更加...

    4.Spring中的JdbcTemplate,Spring中的的事务,

    通过本章节的学习,您应该能够掌握如何使用JdbcTemplate进行基本的数据库操作,以及如何在Spring中配置和使用声明式事务来管理复杂的业务流程。这些技能对于开发基于Spring框架的应用程序至关重要。

    基于注解的Spring JdbcTemplate

    本教程将深入探讨如何使用基于注解的Spring JdbcTemplate进行数据库操作,特别适合初学者入门学习。 ### 1. Spring JdbcTemplate简介 Spring JdbcTemplate提供了一个面向对象的接口,用于执行SQL查询、更新和存储...

    spring-springMvc-jdbctemplate.rar

    Spring框架支持多种数据访问策略,其中JdbcTemplate是用于简化数据库操作的一个组件。 Spring MVC是Spring框架的一部分,专门用于构建Web应用。它遵循模型-视图-控制器(Model-View-Controller, MVC)设计模式,将...

    spring mvc注解jdbctemplate

    在Spring MVC框架中,JdbcTemplate是一个非常重要的组件,它提供了对数据库操作的简化API,使得开发者可以更加方便地执行SQL语句,而无需过多关注事务管理、异常处理等底层细节。本文将深入探讨如何在Spring MVC中...

    SpringBoot框架Datasource注入

    在实际开发中,`DataSource`不仅仅用于数据库连接,还可以配合Spring的JdbcTemplate、NamedParameterJdbcTemplate或JPA等工具来执行SQL查询,实现数据的CRUD操作。通过Spring Data JPA,我们甚至可以进一步简化持久...

    Spring JdbcTemplate 常用方法整理

    Spring的JdbcTemplate是Spring框架中用于简化数据库操作的工具类,它是基于JDBC但又抽象出了一层,避免了直接与数据库驱动API交互,从而提高了代码的可读性和可维护性。本文将深入探讨Spring JdbcTemplate的常用方法...

Global site tag (gtag.js) - Google Analytics