spring-使用JdbcTemplate完成查询所有记录-RowMapper
一、创建spring项目
项目名称:spring101306
二、在项目上添加jar包
1.在项目中创建lib目录
/lib
2.在lib目录下添加spring支持
commons-logging.jar
junit-4.10.jar
log4j.jar
mysql-connector-java-5.1.18-bin.jar
spring-beans-3.2.0.RELEASE.jar
spring-context-3.2.0.RELEASE.jar
spring-core-3.2.0.RELEASE.jar
spring-expression-3.2.0.RELEASE.jar
spring-jdbc-3.2.0.RELEASE.jar
spring-tx-3.2.0.RELEASE.jar
com.springsource.com.mchange.v2.c3p0-0.9.1.2.jar
三、在项目中添加配置文件与属性文件
1.在项目中创建conf目录
2.在conf目录下添加属性文件
属性文件名称:jdbc.properties
属性文件内容:
jdbc.url=jdbc:mysql://localhost:3306/spring
jdbc.driver=com.mysql.jdbc.Driver
jdbc.username=root
jdbc.password=root
2.在conf目录下添加spring核心配置文件
配置文件名称:applicationContext.xml
配置文件内容:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 加载属性文件 -->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!-- 1.配置数据库连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="jdbcUrl" value="${jdbc.url}"></property>
<property name="driverClass" value="${jdbc.driver}"></property>
<property name="user" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
</beans>
四、实现bean设计
1.在src目录下创建实体bean的包
包名:cn.jbit.spring101306.domain
2.在包下创建实体bean
public class Temp {
private Integer tempId;
private String tempName;
//省略get and set
}
五、设计Dao层
1.在src目录下创建dao层的包
包名:cn.jbit.spring101306.dao
2.在包下创建dao层的接口与实现类
1)接口设计
接口名称:ITempDao.java
接口内容:
public interface ITempDao {
public List<Temp> findAll2();
}
2)接口实现类设计
实现类名称:TempDaoImpl.java
实现类内容:
public class TempDaoImpl extends JdbcDaoSupport implements ITempDao {
@Override
public List<Temp> findAll1() {
List<Temp> temps = this.getJdbcTemplate().query("select * from temp", new ResultSetExtractor<List<Temp>>(){
@Override
public List<Temp> extractData(ResultSet rs) throws SQLException,
DataAccessException {
List<Temp> temps = new ArrayList<Temp>();
while(rs.next()){
int tid = rs.getInt("tid");
String tname= rs.getString("tname");
Temp temp = new Temp();
temp.setTempId(tid);
temp.setTempName(tname);
temps.add(temp);
}
return temps;
}
});
return temps;
}
}
六、在核心配置文件中配置Dao
<!-- 配置Dao -->
<bean id="tempdao" class="cn.jbit.spring101306.dao.TempDaoImpl">
<!-- 为jdbcTemplate进行注入 -->
<property name="dataSource" ref="dataSource"></property>
</bean>
七、测试
1.在项目上创建test目录
/test
2.在test目录下创建测试包
包名:cn.jbit.spring101301.dao
3.在测试包下创建测试类
测试类名:JdbcTemplateDemo.java
测试类的内容:
public class JdbcTemplateDemo {
/**
* 使用spring jdbctemplate查询所有
*/
@Test
public void testJdbcTemplateFindAllByRowMapper(){
ApplicationContext context = new ClassPathXmlApplicationContext("classpath:applicationContext.xml");
ITempDao tempDao = (ITempDao) context.getBean("tempdao");
List<Temp> temps = tempDao.findAll2();
for (Temp temp : temps) {
System.out.println(temp.getTempId()+"------->"+temp.getTempName());
}
}
}
本文出自 “素颜” 博客,请务必保留此出处http://suyanzhu.blog.51cto.com/8050189/1563392
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。