您的位置:首页 > 编程语言 > Java开发

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

2007-05-29 20:43 801 查看
首先使用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");


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);


}










}



结果如下:保存了5条数据,后三条为批量保存,如果我们的数据库不支持批量,则spring会模拟批量操作,实际还是一条条的进行保存

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: