读书人

Spring施用JdbcTemplate操作数据库-写

发布时间: 2012-07-02 17:46:22 作者: rapoo

Spring使用JdbcTemplate操作数据库---写数据篇

首先使用mysql建立数据库,并建立表如下:

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

?

Spring的JDBC框架承担了资源管理和错误处理的重担,使你的JDBC代码非常干净,这就是spring为我们提供的模板类-?JdbcTemplate,他是线程安全的

首先,我们编写配置文件,这里数据库链接部队使用了apache的pool和DBCP作为连接池

我们为PersonDAO这个数据库操作类,注入JdbcTemplate

?

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

?

下面是我们的javaBean

?

Spring施用JdbcTemplate操作数据库-写数据篇package?SpringJDBCSupport.WriteData;
Spring施用JdbcTemplate操作数据库-写数据篇import?com.mysql.jdbc.Driver;
Spring施用JdbcTemplate操作数据库-写数据篇public?class?Person?{
Spring施用JdbcTemplate操作数据库-写数据篇??private?String?name;
Spring施用JdbcTemplate操作数据库-写数据篇??private?String?password;
Spring施用JdbcTemplate操作数据库-写数据篇??private?String?address;
Spring施用JdbcTemplate操作数据库-写数据篇??public?Person(String?name,String?password,String?address){
Spring施用JdbcTemplate操作数据库-写数据篇??????this.name=name;
Spring施用JdbcTemplate操作数据库-写数据篇??????this.password=password;
Spring施用JdbcTemplate操作数据库-写数据篇??????this.address=address;
Spring施用JdbcTemplate操作数据库-写数据篇??}
Spring施用JdbcTemplate操作数据库-写数据篇public?String?getAddress()?{
Spring施用JdbcTemplate操作数据库-写数据篇????return?address;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?void?setAddress(String?address)?{
Spring施用JdbcTemplate操作数据库-写数据篇????this.address?=?address;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?String?getName()?{
Spring施用JdbcTemplate操作数据库-写数据篇????return?name;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?void?setName(String?name)?{
Spring施用JdbcTemplate操作数据库-写数据篇????this.name?=?name;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?String?getPassword()?{
Spring施用JdbcTemplate操作数据库-写数据篇????return?password;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?void?setPassword(String?password)?{
Spring施用JdbcTemplate操作数据库-写数据篇????this.password?=?password;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇

?

这是我们的数据库访问类:

包含了三个方法,其中execute方法是有三个参数,sql,params,type,定义type表示这是一个类型安全的方法

Spring施用JdbcTemplate操作数据库-写数据篇package?SpringJDBCSupport.WriteData;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇import?java.sql.PreparedStatement;
Spring施用JdbcTemplate操作数据库-写数据篇import?java.sql.SQLException;
Spring施用JdbcTemplate操作数据库-写数据篇import?java.sql.Types;
Spring施用JdbcTemplate操作数据库-写数据篇import?java.util.List;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇import?org.springframework.jdbc.core.BatchPreparedStatementSetter;
Spring施用JdbcTemplate操作数据库-写数据篇import?org.springframework.jdbc.core.JdbcTemplate;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇public?class?PersonDAO?{
Spring施用JdbcTemplate操作数据库-写数据篇??private?JdbcTemplate?jdbcTemplate;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇public?JdbcTemplate?getJdbcTemplate()?{
Spring施用JdbcTemplate操作数据库-写数据篇????return?jdbcTemplate;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇public?void?setJdbcTemplate(JdbcTemplate?jdbcTemplate)?{
Spring施用JdbcTemplate操作数据库-写数据篇????this.jdbcTemplate?=?jdbcTemplate;
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇public?int?insertPersonUseUpdate(Person?person){
Spring施用JdbcTemplate操作数据库-写数据篇????String?sql="insert?into?login?values(?,?,?)";
Spring施用JdbcTemplate操作数据库-写数据篇????Object[]?params=new?Object[]{
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getName(),
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getPassword(),
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getAddress()
Spring施用JdbcTemplate操作数据库-写数据篇????};
Spring施用JdbcTemplate操作数据库-写数据篇????return?this.getJdbcTemplate().update(sql,params);
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?int?insertPersonUseExecute(Person?person){
Spring施用JdbcTemplate操作数据库-写数据篇????String?sql="insert?into?login?values(?,?,?)";
Spring施用JdbcTemplate操作数据库-写数据篇????Object[]?params=new?Object[]{
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getName(),
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getPassword(),
Spring施用JdbcTemplate操作数据库-写数据篇????????????person.getAddress()
Spring施用JdbcTemplate操作数据库-写数据篇????};
Spring施用JdbcTemplate操作数据库-写数据篇????int[]?types=new?int[]{
Spring施用JdbcTemplate操作数据库-写数据篇????????????Types.VARCHAR,
Spring施用JdbcTemplate操作数据库-写数据篇????????????Types.VARCHAR,
Spring施用JdbcTemplate操作数据库-写数据篇????????????Types.VARCHAR
Spring施用JdbcTemplate操作数据库-写数据篇????};
Spring施用JdbcTemplate操作数据库-写数据篇????return?this.getJdbcTemplate().update(sql,params,types);
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇public?int[]?updatePersonUseBatchUpdate(?final?List?persons){
Spring施用JdbcTemplate操作数据库-写数据篇????String?sql="insert?into?login?values(?,?,?)";
Spring施用JdbcTemplate操作数据库-写数据篇????BatchPreparedStatementSetter?setter=null;
Spring施用JdbcTemplate操作数据库-写数据篇????setter=new?BatchPreparedStatementSetter(){
Spring施用JdbcTemplate操作数据库-写数据篇????????public?int?getBatchSize(){
Spring施用JdbcTemplate操作数据库-写数据篇????????????return?persons.size();
Spring施用JdbcTemplate操作数据库-写数据篇????????}
Spring施用JdbcTemplate操作数据库-写数据篇????????public?void?setValues(PreparedStatement?ps,int?index)?throws?SQLException{
Spring施用JdbcTemplate操作数据库-写数据篇????????????Person?person=(Person)persons.get(index);
Spring施用JdbcTemplate操作数据库-写数据篇????????????ps.setString(1,person.getName());
Spring施用JdbcTemplate操作数据库-写数据篇????????????ps.setString(2,person.getPassword());
Spring施用JdbcTemplate操作数据库-写数据篇????????????ps.setString(3,person.getAddress());
Spring施用JdbcTemplate操作数据库-写数据篇????????}
Spring施用JdbcTemplate操作数据库-写数据篇????};
Spring施用JdbcTemplate操作数据库-写数据篇????return?this.getJdbcTemplate().batchUpdate(sql,setter);
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇??
Spring施用JdbcTemplate操作数据库-写数据篇}
Spring施用JdbcTemplate操作数据库-写数据篇

?

测试代码:

?

Spring施用JdbcTemplate操作数据库-写数据篇package?SpringJDBCSupport.WriteData;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇import?java.io.File;
Spring施用JdbcTemplate操作数据库-写数据篇import?java.util.ArrayList;
Spring施用JdbcTemplate操作数据库-写数据篇import?java.util.List;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇import?org.springframework.beans.factory.BeanFactory;
Spring施用JdbcTemplate操作数据库-写数据篇import?org.springframework.beans.factory.xml.XmlBeanFactory;
Spring施用JdbcTemplate操作数据库-写数据篇import?org.springframework.core.io.FileSystemResource;
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇public?class?TestJDBCTemplate?{
Spring施用JdbcTemplate操作数据库-写数据篇
Spring施用JdbcTemplate操作数据库-写数据篇????public?static?String?filePath="";
Spring施用JdbcTemplate操作数据库-写数据篇????public?static?BeanFactory?factory=null;
Spring施用JdbcTemplate操作数据库-写数据篇????public?static?void?main(String[]?args)?{
Spring施用JdbcTemplate操作数据库-写数据篇????????filePath=System.getProperty("user.dir")+File.separator+"SpringJDBCSupport"+File.separator+"WriteData"+File.separator+"hello.xml";
Spring施用JdbcTemplate操作数据库-写数据篇????????factory=new?XmlBeanFactory(new?FileSystemResource(filePath));
Spring施用JdbcTemplate操作数据库-写数据篇????????PersonDAO?personDAO=(PersonDAO)factory.getBean("personDAO");
Spring施用JdbcTemplate操作数据库-写数据篇????????/*
Spring施用JdbcTemplate操作数据库-写数据篇?????????*?准备数据
Spring施用JdbcTemplate操作数据库-写数据篇?????????*/
Spring施用JdbcTemplate操作数据库-写数据篇????????Person?p1=new?Person("test1","test1","test1");

读书人网 >其他数据库

热点推荐