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、使用spring的IOC容器中的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;
}
}