`

spring 数据库访问

 
阅读更多

一: 数据访问模版化 : spring将数据访问过程中固定的和可变的部分明确划分为两个不同的类: 模板和回调 

 模板 : 事务控制,管理资源,处理异常

 回调 : 创建语句,绑定参数,整理数据集

 spring 提供了: jdbcTemplate 和 HibernateTemplate 或 JpaTemplate 

 

二: 使用数据访问模板

方式1: 将其配置为spring上下文中的bean并将其直入到应用程序的DAO中

 

方式2: 使用spring的DAO支持类进一步简化应用程序的DAO配置 (Spring提供了DAO支持类,而将业务自己的DAO类作为它的子类)当编写应用程序自己的DAO实现时,可以继承自DAO支持类并调用模板获取方法类直接访问底层的数据访问模板。列如应用程序的DAO继承自JdbcDaoSupport,那么只需要getJdbcTemplate()方法就可以获得jdbcTemplate并使用它。

 

三:spring上下文中配置数据源bean的多种方式

1、通过jdbc驱动程序定义的数据源

 

2、通过jndi查找的数据源 : 数据源完全可以在应用程序之外进行管理,这样应用程序只需在访问数据库的时候查找数据源就可以了。

 

3、连接池的数据源:spring并没有提供数据源连接池实现。可以DBCP

 

DBCP包含了多个提供连接池功能的数据源,其中BasicDataSource是常用的

 

 

四、spring 访问数据库

1: jdbc方式: 使用jdbc模板承担了资源管理和异常处理的工作,从而简化了jdbc代码,让我们只需编写从数据库读写数据的代码。

jdbcTemplate : 最基本的Spring Jdbc模板,这个模板支持最简单的jdbc数据库访问功能以及简单的索引参数查询。

NamedParameterJdbcTemplate : 使用该模板类查询时,可以将查询值以命名参数的形式绑定到sql中。

 

SimpleJdbcTemplate: 该模板包含自动装箱,泛型,可变参数列表简化jdbc模板。

需要配置 : SimpleJdbcTemplate 和 SimpleJdbcTemplateSpitterDao

 

2 : spring中集成hibernate

spring 对ORM框架的支持提供的服务: spring声明式事务的集成支持,透明的异常处理,线程安全的模版类,dao支持类,资源管理。

 

3: spring与java持久化API

配置实体管理工厂 : 基于Java持久化api的应用程序使用EntityManagerFactory的实现类来获取EntityManager实例。

包括两种类型,应用程序管理类型和容器管理类型。他们二者之间唯一值得关注的区别是,在spring应用上下文中如何进行配置。其中容器管理类型,可以将数据源信息配置在Spring应用上下文,而不是在persistence.xml文件中。

 

 

 

 

 

 

 

 

 

 

 

 

 

分享到:
评论

相关推荐

    Spring数据库访问之ORM(三)

    总结,Spring数据库访问中的ORM技术是企业级应用开发的重要组成部分。通过Spring对JPA、Hibernate、MyBatis等ORM框架的集成,我们可以轻松地在Java应用中进行数据库操作。同时,Spring提供的事务管理和数据源连接池...

    Spring数据库访问(HSQL)(三)

    在"Spring数据库访问(HSQL)(三)"这个主题中,博主可能详细讲解了如何配置Spring与HSQL的集成,以及如何利用Spring的数据访问组件进行数据库操作。 首先,我们需要了解Spring的JdbcTemplate和HibernateTemplate...

    Spring数据库访问之异常处理

    在Spring框架中,数据库访问是核心功能之一,它提供了丰富的工具和API来简化与数据库的交互。本篇文章将深入探讨Spring中的数据库异常处理机制,帮助开发者更好地理解和处理在数据库操作中可能遇到的问题。 首先,...

    Spring数据库访问(HSQL)(四)

    在本篇博文中,我们将深入探讨Spring框架在数据库访问方面的应用,特别关注使用HSQL内存数据库的实践。Spring是Java领域最广泛使用的轻量级框架之一,它为开发者提供了全面的事务管理、数据访问集成以及IoC...

    Spring数据库访问之iBatis

    为了丰富博客专栏【Spring数据库访问系列】的内容,完善Spring数据库访问的体系,现在我们介绍Spring对iBatis的支持。相对于Hibernate等ORM框架的全自动SQL,那么iBatis则属于半自动化的ORM框架,我们需要编写SQL...

    访问数据库基本封装(spring/hibernate/ibatis)

    首先,Spring框架以其强大的依赖注入和面向切面编程闻名,它不仅是一个全面的后端开发框架,还提供了多种数据库访问方式。Spring JDBC模块提供了对JDBC的简单封装,使得编写SQL和处理结果集变得更简洁。同时,Spring...

    初学SpringCloud连接Oracle数据库

    在初学SpringCloud的过程中,与Oracle数据库的连接是构建分布式系统的一个重要环节。SpringCloud作为一个微服务框架,提供了丰富的服务治理功能,而数据库作为数据存储的核心,与SpringBoot的集成使得我们可以轻松...

    spring和数据库层的结合

    Spring框架通过提供高级的JDBC支持,简化了数据库访问代码的编写。 1. **数据源配置**:Spring允许配置数据源,这样就封装了数据库连接的基本信息,并进行了优化处理。这种方式不仅可以提高性能,还能够减少代码量...

    Spring-test做数据库操作的单元测试2-跨库访问

    这篇博客"Spring-test做数据库操作的单元测试2-跨库访问"探讨了如何利用Spring-test进行数据库操作的测试,尤其是涉及到跨库访问的场景。在企业级应用开发中,常常需要处理多个数据库的情况,例如主从数据库、读写...

    通过Spring Boot配置动态数据源访问多个数据库的实现代码

    在Spring Boot项目中,数据库访问是通过Restful接口来实现的,该接口用于提供数据库访问的服务。 项目结构 该项目的结构主要包括以下几个部分: * config:数据源配置管理类 * datasource:自己实现的数据源管理...

    webservice,通过spring mybiatis 访问数据库mysql

    在本项目中,我们结合了Spring、MyBatis以及MySQL,构建了一个能够通过WebService接口访问数据库的应用。下面将详细阐述这些技术及其整合过程。 1. **Spring框架**: Spring是一个全面的Java企业级应用开发框架,...

    Spring Boot 与 Kotlin 使用JdbcTemplate连接MySQL数据库的方法

    JdbcTemplate是Spring提供的一种简化数据库访问的工具,它提供了模板方法来执行SQL语句,使得数据库操作更加安全且易于维护。接下来,我们将详细讨论如何在Spring Boot项目中配置数据源,并使用JdbcTemplate进行数据...

    dwr与spring数据库环境集成

    "dwr与spring数据库环境集成"是一个常见的技术实践,它涉及到Direct Web Remoting (DWR)框架、Spring框架以及数据库(如MySQL)的整合。在这个场景中,DWR用于实现浏览器与服务器之间的异步通信,Spring作为一款强大...

    Spring Security 把授权信息写入数据库

    【Spring Security 把授权信息写入数据库】 Spring Security是一个强大的安全管理框架,用于处理Java应用程序的安全需求,包括认证和授权。在从Acegi安全框架转换到Spring Security 2.0时,一个重要的变化就是如何...

    Spring Dao层设计

    Spring 数据库访问的支持。包括统一异常体系和Spring的Template+CallBack的解读

    Springcloud 多数库 多数据源整合,查询动态切换数据库

    可以通过Spring Security来控制用户的数据库访问权限,防止未经授权的数据库操作。 9. **测试与监控**:在开发和运行阶段,对多数据源的测试和监控同样重要。使用像Spring Boot Actuator这样的工具,可以实时监控...

    基于Spring与Hibernate的数据库访问技术研究

    ### 基于Spring与Hibernate的数据库访问技术研究 #### 引言 在现代企业级应用开发中,数据持久层的设计至关重要,它涉及到如何高效、安全地存储和检索数据。随着互联网技术的发展,传统的两层架构(客户端/服务器...

    Spring所需jar包包括数据库连接池

    在"SpringIOC基本包"中,通常会包含Spring框架的基础组件,如核心容器(Core Container)、数据访问/集成(Data Access/Integration)等模块。核心容器包括BeanFactory和ApplicationContext,它们是IOC容器的实现,...

Global site tag (gtag.js) - Google Analytics