首先,假设如下SQL表中有数据username=test1,passwd=test1,address=test1
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();
}
}
DAO:
其中getPersonByRowCallbackHandler方法根据username获得person对象
package SpringJDBCSupport.ReadData;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import java.util.List;
import org.springframework.jdbc.core.BatchPreparedStatementSetter;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.RowCallbackHandler;
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);
}
public Person getPersonByRowCallbackHandler(String username)...{
String sql="select * from login where username=?";
final Person person=new Person();
final Object params[]=new Object[]...{username};
this.getJdbcTemplate().query(sql,params,new RowCallbackHandler()...{
public void processRow(ResultSet rs)throws SQLException...{
person.setName(rs.getString("username"));
p
分享到:
相关推荐
spring-jdbcTemplate实例工程
主要介绍了详解在spring中使用JdbcTemplate操作数据库的几种方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
使用Spring的JdbcTemplate实现分页功能
spring中使用JdbcTemplate操作数据库crud,一图详解(脑图)
使用Spring的JdbcTemplate调用Oracle的存储过程
04JdbcTemplate操作数据库.md
JdbcTemplate操作数据库实现添加功能
strut2+spring+springjdbctemplate做的简易登录系统
简单介绍如何使用Spring Boot使用JdbcTemplate与MySQL进行数据库操作
SpringBoot操作数据库JdbcTemplate--SB系列之005的配套项目代码。 环境: win11 工具: idea 2017 jdk: 1.8 数据库: mysql5.5 maven : 3.2.1 项目:maven 导入 首先介绍一下本人与本篇: 因为本篇之后其实...
使用spring+springmvc+jdbcTemplate 数据库使用orcal、redis 完成一个webdemo
spring 中对大数据的处理,包括clob,blob的数据。比之jdbc下简便很多。
Spring-JdbcTemplate
SSH笔记-Spring JdbcTemplate,使用JdbcTemplate对数据库进行操作,使用具名参数和JDBC模板,简化操作
基于springboot框架实现一些常用的功能
主要介绍了SpringBoot使用JdbcTemplate操作数据库,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
Spring:JdbcTemplate使用指南 Spring:JdbcTemplate使用指南
本篇文章主要介绍了Spring Boot中使用jdbctemplate 操作MYSQL数据库实例,具有一定的参考价值,有兴趣的可以了解一下。
配制Spring事务和JdbcTemplate使用 配制Spring事务和JdbcTemplate使用