Spring 之数据访问 JdbcTemplate

springMVC的数据访问的两种方式
配置数据源,这里需要使用到commons-dbcp.jar commons-pool.jar spring-jdbc.jar 这三个jar
1、使用 Commons DBCP 创建jdbcTemplate
BasicDateSource dataSource=new BasicDateSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/test");
dataSource.setUsername("root");
dataSource.setPassword("root");
JdbcTemplate jdbcTemplate=new JdbcTemplate(dataSource);
2、使用springIOC容器中的jdbcTemplate
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
  <property name="url" value="jdbc:mysql://localhost:3306/test" />
  <property name="driverClassName" value="com.mysql.jdbc.Driver" />
  <property name="username" value="root" />
  <property name="password" value="root" />
</bean>
 
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
  <property name="dataSource" ref="dataSource"></property>
</bean>
3、在操作数据库是使用jdbcTemplate
 定义一个接口:
package com.springmvc.dao;
import java.util.List;
import com.springmvc.domain.User;
public interface UserDao {
        public List<User> getUserList();
}
写一个 UserDao 接口的实现类:
package com.springmvc.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.core.ResultSetExtractor;
import org.springframework.stereotype.Repository;
import com.springmvc.domain.User;
@SuppressWarnings("all")
@Repository("userDaoImpl")
public class UserDaoImpl implements UserDao{
        @Resource(name="jdbcTemplate")
    private JdbcTemplate jdbcTemplate;//注入jdbcTemplate
        public List<User> getUserList() {
        List<User> lists=jdbcTemplate.query("select * from users", new ResultSetExtractor(){//使用jdbcTemplate对数据库进行操作。
         @Override
                        public Object extractData(ResultSet res) throws SQLException,DataAccessException {
                 List<User> users=new ArrayList<User>();
                 while(res.next()){
                         User user=new User();
                         user.setId(res.getInt("id"));
                         user.setUserName(res.getString("username"));
                         user.setAge(res.getInt("age"));
                         user.setPassword(res.getString("password"));
                         user.setEmail(res.getString("email"));
                         users.add(user);
                 }
                 return users;
                        }});
                return lists;
        }
}










  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值