`
独善其身008
  • 浏览: 171407 次
  • 性别: Icon_minigender_2
  • 来自: 苏州
文章分类
社区版块
存档分类
最新评论

Spring使用JdbcTemplate操作数据库---使用RowMapperResultSetExtractor读数据篇

 
阅读更多

首先建立数据表:

CREATE TABLE `login` (
  `username` varchar(10) default NULL,
  `passwd` varchar(10) default NULL,
  `address` varchar(10) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=gb2312;

 

配置文件:

 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd" >
<beans>
 
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
   
<property name="driverClassName">
     
<value>com.mysql.jdbc.Driver</value>
   
</property>
   
<property name="url">
     
<value>jdbc:mysql://localhost:3306/javaee</value>
   
</property>
   
<property name="username">
     
<value>root</value>
   
</property>
   
<property name="password">
     
<value>1234</value>
   
</property>
 
</bean>
 
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
   
<property name="dataSource">
     
<ref local="dataSource"/>
   
</property>
 
</bean>

<bean id="personDAO" class="SpringJDBCSupport.ReadData.PersonDAO">
  
<property name="jdbcTemplate">
    
<ref local="jdbcTemplate"/>
  
</property>
</bean> 
</beans>

 JavaBean

 

package SpringJDBCSupport.ReadData;
import com.mysql.jdbc.Driver;
public class Person {
  
private String name;
  
private String password;
  
private String address;
  
public Person(){
      
  }

  
public Person(String name,String password,String address){
      
this.name=name;
      
this.password=password;
      
this.address=address;
  }

public String getAddress() {
    
return address;
}

public void setAddress(String address) {
    
this.address = address;
}

public String getName() {
    
return name;
}

public void setName(String name) {
    
this.name = name;
}

public String getPassword() {
    
return password;
}

public void setPassword(String password) {
    
this.password = password;
}

public String toString(){
    
return this.getName()+"-"+this.getPassword()+"-"+this.getAddress();
}

}

 

编写自定义RowMapper

 

package SpringJDBCSupport.ReadData;

import java.sql.ResultSet;
import java.sql.SQLException;

import org.springframework.jdbc.core.RowMapper;

public class PersonRowMapper implements RowMapper {

    
public Object mapRow(ResultSet rs, int index) throws SQLException {
        Person person
=new Person();
        person.setName(rs.getString(
"username"));
        person.setPassword(rs.getString(
"passwd"));
        person.setAddress(rs.getString(
"address"));
        
return person;
    }


}

 

测试代码:

 

package SpringJDBCSupport.ReadData;

import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.springframework.core.io.FileSystemResource;

public class TestJDBCTemplate {

    
public static String filePath="";
    
public static BeanFactory factory=null;
    
public static void main(String[] args) {
        filePath
=System.getProperty("user.dir")+File.separator+"SpringJDBCSupport"+File.separator+"ReadData"+File.separator+"hello.xml";
        factory
=new XmlBeanFactory(new FileSystemResource(filePath));
        PersonDAO personDAO
=(PersonDAO)factory.getBean("personDAO");
        
/*
         * 准备数据
         
*/

        Person p1
=new Person("test1","test1","test1");
        Person p2
=new Person("test2","test2","test2");
        Person p3
=new Person("test3","test3","test3");
        Person p4
=new Person("test4","test4","test4");
        Person p5
=new Person("test5","test5","test5");
        List persons
=new ArrayList();
        persons.add(p3);
        persons.add(p4);
        persons.add(p5);
        
//使用jdbcTemplate.update方式
        personDAO.insertPersonUseUpdate(p1);
        
//使用jdbcTemplate.execute方式
        personDAO.insertPersonUseExecute(p2);
    
//    //使用jdbcTemplate批处理方式
        personDAO.updatePersonUseBatchUpdate(persons);
        
        
//使用RowCallbackHandler执行一次查询,并打印person信息
        System.out.println(personDAO.getPersonByRowCallbackHandler("test1"));
        List a
=personDAO.getPersonsByMapperResultReader();
        
for (Iterator iter = a.iterator(); iter.hasNext();) 
{
            System.out.println((Person)iter.next());
            
        }

    }

    
    

}

 

运行程序:输出为以下结果,红色部分为查询结果集

test1-test1-test1
test1-test1-test1
test2-test2-test2
test3-test3-test3
test4-test4-test4
test5-test5-test5

 

我们完全可以用这个方法代替RowCallbackHandler,用一个自定义的RowMapper结局单个查询和结果集查询两种方式,返回单个对象是,只要修改

List result=(ArrayList)this.getJdbcTemplate().query(sql,params,new RowMapperResultSetExtractor(new PersonRowMapper()));
return result.get(0);
}

即可


分享到:
评论

相关推荐

    spring-jdbcTemplate实例工程

    在这个实例工程中,我们将深入探讨Spring JdbcTemplate的基本使用、优势以及常见操作。 一、Spring JdbcTemplate简介 Spring JdbcTemplate的出现是为了弥补原生JDBC在编码上的繁琐,它通过模板方法模式,将SQL执行...

    使用JdbcTemplate操作数据库.zip

    这样,我们就构建了一个简单的Spring Boot应用,使用JdbcTemplate实现了对数据库的基本操作。用户可以通过HTTP接口查询所有用户和添加新用户。这个项目为你提供了一个基础模板,你可以根据实际需求扩展其他数据库...

    springboot集成达梦数据库-所需jar包

    在本文中,我们将深入探讨如何在Spring Boot项目中集成达梦数据库。达梦数据库是一款国产高性能、高可靠的大型关系型数据库管理...通过这些步骤,你可以顺利地在Spring Boot应用中使用达梦数据库进行数据存储和处理。

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

    本篇文章将详细介绍如何在Spring中使用JdbcTemplate进行数据库操作,包括设置依赖、创建数据表和实体类、配置数据源、创建JdbcTemplate实例以及执行各种数据库操作。 首先,要使用JdbcTemplate,需要在项目中引入...

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

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

    使用Spring的JdbcTemplate实现分页功能

    使用Spring的JdbcTemplate实现分页功能

    SpringJdbcTemplate封装工具类

    在描述中提到的“规范model格式接口”,可能是指创建一套标准的数据访问接口,这些接口定义了CRUD(Create、Read、Update、Delete)操作,并由SpringJdbcTemplate实现具体的数据库交互逻辑。这样做的好处是解耦了...

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

    通过以上步骤,我们成功地在Spring Boot应用中配置了多数据源,并使用了`JdbcTemplate`进行数据库操作。这个过程的关键在于正确配置数据源,创建并注入相应的`JdbcTemplate` bean,然后在业务逻辑中选择合适的数据源...

    Spring--JdbcTemplate.pdf

    标题中提到的"JdbcTemplate"是Spring框架中提供的一个用于简化数据库操作的JDBC抽象库。它是对Java标准数据库编程接口JDBC的一种封装,旨在简化JDBC编程,减少样板代码,使得开发者在使用Spring框架时能够更便捷地对...

    spring-springMvc-jdbctemplate.rar

    开发者可能需要配置Spring的数据源(DataSource)来连接Oracle数据库,并使用JdbcTemplate进行数据操作。 另外,项目还引入了Redis,一个内存中的数据结构存储系统,常被用作数据库、缓存和消息中间件。在Web应用中...

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

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

    Spring-JdbcTemplate

    `Spring-JdbcTemplate` 是 Spring 框架中的一个核心模块,主要用于简化数据库操作,提供了强大的数据访问功能。它通过模板方法设计模式封装了 SQL 的执行,使得开发者无需直接与 JDBC API 打交道,从而降低了数据库...

    spring的jdbcTemplate小案例

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

    使用Spring的JdbcTemplate调用Oracle的存储过程

    使用Spring的JdbcTemplate调用Oracle的存储过程

    04JdbcTemplate操作数据库.md

    04JdbcTemplate操作数据库.md

    strut2+spring+springjdbctemplate做的简易登录系统

    Spring JDBC Template是Spring提供的一个简化数据库操作的工具,它封装了JDBC的繁琐部分,让开发者可以更专注于业务逻辑。 在这个“简易登录系统”中,Struts2主要承担用户界面和控制器之间的交互。用户在登录页面...

    SpringBoot使用JdbcTemplate操作数据库

    SpringBoot使用JdbcTemplate操作数据库是Java开发中常见的一种方式,它简化了数据库访问的复杂性。JdbcTemplate是Spring框架提供的一套操作数据库的模板类,它提供了大量的静态方法来执行SQL语句,包括增删改查...

    Spring 学习 JdbcTemplate,模板模式,回调

    Spring JdbcTemplate简化了数据库操作,通过模板模式抽象出通用的流程,而回调机制则提供了定制化数据处理的能力。理解并熟练运用这些概念,能够帮助开发者更高效地进行数据库相关的编程,提高代码质量和可维护性。...

Global site tag (gtag.js) - Google Analytics