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

系统 1468 0

首先使用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

 

<? 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.WriteData.PersonDAO" >
  
< property  name ="jdbcTemplate" >
    
< ref  local ="jdbcTemplate" />
  
</ property >
</ bean >  
</ beans >

 

下面是我们的javaBean

 

package  SpringJDBCSupport.WriteData;
import  com.mysql.jdbc.Driver;
public   class  Person  ... {
  
private  String name;
  
private  String password;
  
private  String address;
  
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;
}

}

 

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

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

package  SpringJDBCSupport.WriteData;

import  java.sql.PreparedStatement;
import  java.sql.SQLException;
import  java.sql.Types;
import  java.util.List;

import  org.springframework.jdbc.core.BatchPreparedStatementSetter;
import  org.springframework.jdbc.core.JdbcTemplate;

public   class  PersonDAO  ... {
  
private  JdbcTemplate jdbcTemplate;

public  JdbcTemplate getJdbcTemplate()  ... {
    
return  jdbcTemplate;
}


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


public   int  insertPersonUseUpdate(Person person) ... {
    String sql
= " insert into login values(?,?,?) " ;
    Object[] params
= new  Object[] ... {
            person.getName(),
            person.getPassword(),
            person.getAddress()
    }
;
    
return   this .getJdbcTemplate().update(sql,params);
}

public   int  insertPersonUseExecute(Person person) ... {
    String sql
= " insert into login values(?,?,?) " ;
    Object[] params
= new  Object[] ... {
            person.getName(),
            person.getPassword(),
            person.getAddress()
    }
;
    
int [] types = new   int [] ... {
            Types.VARCHAR,
            Types.VARCHAR,
            Types.VARCHAR
    }
;
    
return   this .getJdbcTemplate().update(sql,params,types);
}

public   int [] updatePersonUseBatchUpdate(  final  List persons) ... {
    String sql
= " insert into login values(?,?,?) " ;
    BatchPreparedStatementSetter setter
= null ;
    setter
= new  BatchPreparedStatementSetter() ... {
        
public   int  getBatchSize() ... {
            
return  persons.size();
        }

        
public   void  setValues(PreparedStatement ps, int  index)  throws  SQLException ... {
            Person person
= (Person)persons.get(index);
            ps.setString(
1 ,person.getName());
            ps.setString(
2 ,person.getPassword());
            ps.setString(
3 ,person.getAddress());
        }

    }
;
    
return   this .getJdbcTemplate().batchUpdate(sql,setter);
}

  
}

 

测试代码:

 

package  SpringJDBCSupport.WriteData;

import  java.io.File;
import  java.util.ArrayList;
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 + " WriteData " + File.separator + " hello.xml " ;
        factory
= new  XmlBeanFactory( new  FileSystemResource(filePath));
        PersonDAO personDAO
= (PersonDAO)factory.getBean( " personDAO " );
        
/**/ /*
         * 准备数据
         
*/

        Person p1
= new  Person( " test1 " , " test1 " , " test1 " );

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


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论