1. 程式人生 > >spring學習(七)spring整合JDBC

spring學習(七)spring整合JDBC

Spring中封裝了一個可操作資料庫的物件,該物件封裝了JDBC技術

使用資料庫

 

一、導包(IDEA的maven工程,在pom.xml檔案中匯入依賴,必須注意依賴,不然會報各種異常)

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"
> <modelVersion>4.0.0</modelVersion> <groupId>demojdbc</groupId> <artifactId>demojdbc</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <dependency> <groupId>junit</groupId> <
artifactId>junit</artifactId> <version>4.12</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>4.2.5.RELEASE</
version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>4.2.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>4.2.5.RELEASE</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.38</version> </dependency> <dependency> <groupId>com.mchange</groupId> <artifactId>c3p0</artifactId> <version>0.9.5.2</version> </dependency> </dependencies> </project>

二、書寫與資料庫對應的bean類

package dyh.bean;

public class User {
    private String username;
    private String sex;
    private String address;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    @Override
    public String toString() {
        return "User{" +
                "username='" + username + '\'' +
                ", sex='" + sex + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}

三、UserDao介面以及它的實現類

import dyh.bean.User;
import java.util.List;
public interface UserDao {
    void save(User user);
    void delete();
    void update();
    User selectById(Integer id);
    List<User> selectList();
    int getListCount();

}
import dyh.bean.User;
import org.springframework.jdbc.core.JdbcTemplate;
import java.util.List;

public class UserDaoImpl implements UserDao {
    
    //把JdbcTemplate交給spring管理
    private JdbcTemplate jt;
    //JdbcTemplate的set方法,不然不能夠依賴注入
    public void setJt(JdbcTemplate jt) {
        this.jt = jt;
    }
    //資料庫插入
    public void save(User user) {
        String sql = "insert into user(username,sex,address) values(?,?,?)";
        jt.update(sql,user.getUsername(),user.getSex(),user.getAddress());
    }

    public void delete() {

    }

    public void update() {

    }

    public User selectById(Integer id) {
        return null;
    }

    public List<User> selectList() {
        return null;
    }

    public int getListCount() {
        return 0;
    }
}

四、配置檔案書寫(IDEA的maven工程,applicationContext.xml與jdbc.properties檔案,必須放在resources資料夾中)

(1)、jdbc.properties檔案

jdbc.jdbcUrl=jdbc:mysql:///school
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.user=root
jdbc.password=dyhroot

(2)、applicationContext.xml檔案

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.2.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd ">

    <!-- 指定spring讀取db.properties配置 -->
    <context:property-placeholder location="classpath:jdbc.properties"  />

    <!-- 1.將連線池放入spring容器 -->
    <bean name="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" >
        <property name="jdbcUrl" value="${jdbc.jdbcUrl}" ></property>
        <property name="driverClass" value="${jdbc.driverClass}" ></property>
        <property name="user" value="${jdbc.user}" ></property>
        <property name="password" value="${jdbc.password}" ></property>
    </bean>
    
    <!-- 2.將JDBCTemplate放入spring容器 -->
    <bean name="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate" >
        <property name="dataSource" ref="dataSource" ></property>
    </bean>

    <!-- 3.將UserDao放入spring容器 -->
    <bean name="userDao" class="dyh.dao.UserDaoImpl" >
         <property name="jt" ref="jdbcTemplate" ></property>
    </bean>
</beans>

五、測試

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = {"classpath:applicationContext.xml"})
public class Demo {
    @Resource(name = "userDao")
    private UserDao userDao;

    @Test
    public void fun1(){

        User u = new User();
        u.setUsername("hhuan");
        u.setSex("man");
        u.setAddress("American");
        userDao.save(u);
    }
}

測試結果:

資料庫新增成功