jdbc框架有不少,包括spring jdbc

1.因爲jdbc鏈接的繁瑣性,故不少公司封裝了jdbc框架,好比spring jdbchtml

2.好比spring jdbc框架中,用jdbctemplate,java

經過jdbcTemplate 提供 int update(String sql, Object... args) 實現增長 、修改 、刪除mysql

代替了原來connection.createStatement().execuate(sql);spring

statemment.executeQuery(),executeUpdate()等方法。sql

甚至包括preparestatement的預處理參數?app

好比:框架

   String sql="select * from user where id=?";
return this.getJdbcTemplate().queryForObject(sql, new UserRowMapper(), id);

3.Spring中關於JDBC的一個輔助類(JDBC Template),它封裝了JDBC的操做,使用起來很是方便。ide

appliactionContext.xml函數

1 <?xml version="1.0" encoding="UTF-8"?>
 2 <beans xmlns="http://www.springframework.org/schema/beans"
 3        xmlns:p="http://www.springframework.org/schema/p"
 4        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 5        xsi:schemaLocation="
 6 http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
 7     
 8     <!--數據源的配置 -->
 9     <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
10         <property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
11         <property name="url" value="jdbc:mysql:///spring"></property>
12         <property name="username" value="root"></property>
13         <property name="password" value=""></property>
14     </bean>
15     
16     
17   
18     <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
19         <property name="dataSource" ref="dataSource"></property>
20     </bean>
21     
22     
23     <bean id="userDao" class="com.curd.spring.impl.UserDAOImpl">
24         <property name="jdbcTemplate" ref="jdbcTemplate"></property>
25     </bean>
26 
27 
28 
29 </beans>

接口:IUserDAO.java工具

 package com.curd.spring.dao;
 2 
 3 import java.util.List;
 4 
 5 import com.curd.spring.vo.User;
 6 
 7 public interface IUserDAO {
 8 
 9     public void addUser(User user);
10 
11     public void deleteUser(int id);
12 
13     public void updateUser(User user);
14 
15     public String searchUserName(int id);
16     
17     public User searchUser(int id);
18     
19     public List<User> findAll();
20 
21 }

接口實現類:UserDAOImpl.java

按照以往Spring的依賴注入,咱們須要在接口實現類中利用構造器去獲取JdbcTemplate

Spring早就幫咱們想到了這點,它爲咱們提供了JdbcDaoSupport支持類,全部DAO繼承這個類,就會自動得到JdbcTemplate(前提是注入DataSource)。

  <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
2         <property name="dataSource" ref="dataSource"></property>
3     </bean>
4     
5     
6     <bean id="userDao" class="com.curd.spring.impl.UserDAOImpl">
7         <property name="jdbcTemplate" ref="jdbcTemplate"></property>
8     </bean>

在咱們的實現類中直接利用getJdbcTemplate就能夠獲取操做對象了。

JdbcTemplate主要提供下列方法:

  一、execute方法:能夠用於執行任何SQL語句,通常用於執行DDL語句;

  二、update方法及batchUpdate方法:update方法用於執行新增、修改、刪除等語句;batchUpdate方法用於執行批處理相關語句;

  三、query方法及queryForXXX方法:用於執行查詢相關語句;

  四、call方法:用於執行存儲過程、函數相關語句。

1 package com.curd.spring.impl;
 2 
 3 import java.sql.ResultSet;
 4 import java.sql.SQLException;
 5 import java.util.List;
 6 
 7 import org.springframework.jdbc.core.RowMapper;
 8 import org.springframework.jdbc.core.support.JdbcDaoSupport;
 9 import com.curd.spring.dao.IUserDAO;
10 import com.curd.spring.vo.User;
11 
12 public class UserDAOImpl extends JdbcDaoSupport implements IUserDAO {
13 
14     public void addUser(User user) {
15         String sql = "insert into user values(?,?,?)";
16         this.getJdbcTemplate().update(sql, user.getId(), user.getUsername(),
17                 user.getPassword());
18     }
19 
20     public void deleteUser(int id) {
21         String sql = "delete from user where id=?";
22         this.getJdbcTemplate().update(sql, id);
23 
24     }
25 
26     public void updateUser(User user) {
27         String sql = "update user set username=?,password=? where id=?";
28         this.getJdbcTemplate().update(sql, user.getUsername(),
29                 user.getPassword(), user.getId());
30     }
31 
32     public String searchUserName(int id) {// 簡單查詢,按照ID查詢,返回字符串
33         String sql = "select username from user where id=?";
34         // 返回類型爲String(String.class)
35         return this.getJdbcTemplate().queryForObject(sql, String.class, id);
36 
37     }
38 
39     public List<User> findAll() {// 複雜查詢返回List集合
40         String sql = "select * from user";
41         return this.getJdbcTemplate().query(sql, new UserRowMapper());
42 
43     }
44 
45     public User searchUser(int id) {
46         String sql="select * from user where id=?";
47         return this.getJdbcTemplate().queryForObject(sql, new UserRowMapper(), id);
48     }
49 
50     class UserRowMapper implements RowMapper<User> {
51      //rs爲返回結果集,以每行爲單位封裝着
52         public User mapRow(ResultSet rs, int rowNum) throws SQLException {
53     
54             User user = new User();
55             user.setId(rs.getInt("id"));
56             user.setUsername(rs.getString("username"));
57             user.setPassword(rs.getString("password"));
58             return user;
59         }
60 
61     }
62 
63 }

測試類:UserTest.java

1 package com.curd.spring.test;
 2 
 3 import java.util.List;
 4 
 5 import org.junit.Test;
 6 import org.springframework.context.ApplicationContext;
 7 import org.springframework.context.support.ClassPathXmlApplicationContext;
 8 
 9 import com.curd.spring.dao.IUserDAO;
10 import com.curd.spring.vo.User;
11 
12 public class UserTest {
13     
14     @Test//
15     public void demo1(){
16         User user=new User();
17         user.setId(3);
18         user.setUsername("admin");
19         user.setPassword("123456");
20         
21         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
22         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
23         dao.addUser(user);
24         
25     }
26     
27     @Test//
28     public void demo2(){
29         User user=new User();
30         user.setId(1);
31         user.setUsername("admin");
32         user.setPassword("admin");
33         
34         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
35         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
36         dao.updateUser(user);
37     }
38     
39     @Test//
40     public void demo3(){
41         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
42         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
43         dao.deleteUser(3);
44     }
45     
46     @Test//查(簡單查詢,返回字符串)
47     public void demo4(){
48         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
49         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
50         String name=dao.searchUserName(1);
51         System.out.println(name);
52     }
53     
54     @Test//查(簡單查詢,返回對象)
55     public void demo5(){
56         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
57         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
58         User user=dao.searchUser(1);
59         System.out.println(user.getUsername());
60     }
61     
62     @Test//查(複雜查詢,返回對象集合)
63     public void demo6(){
64         ApplicationContext applicationContext=new ClassPathXmlApplicationContext("applicationContext.xml");
65         IUserDAO dao=(IUserDAO) applicationContext.getBean("userDao");
66         List<User> users=dao.findAll();
67         System.out.println(users.size());
68     }
69     
70     
71 
72 }

附:

一、Spring 爲每種持久化技術 提供一個支持類,在DAO 中注入 模板工具類
    (1)JDBC : org.springframework.jdbc.core.support.JdbcDaoSupport
    (2)Hibernate 3.0 :org.springframework.orm.hibernate3.support.HibernateDaoSupport
    (3)iBatis :org.springframework.orm.ibatis.support.SqlMapClientDaoSupport

用戶本身編寫DAO 只須要繼承 JdbcDaoSupport, 就能夠注入 JdbcTemplate

二、 經過jdbcTemplate 提供 int update(String sql, Object... args) 實現增長 、修改 、刪除

 

三、簡單查詢,返回原始數據類型, String類型
String sql = "select count(*) from user"; // int queryForInt(String sql)
String sql = "select name from user where id = ? "; // <T> T queryForObject(String sql, Class<T> requiredType, Object... args)

 

四、 複雜查詢
JdbcTemplate 沒有handler, 手動完成對象封裝

編寫實體類 RowMapper
class UserRowMapper implements RowMapper<User> {
  @Override
  public User mapRow(ResultSet rs, int rowNum) throws SQLException {
    // rs 已經指向每一條數據,不須要本身調用 next,將rs指向數據 轉換 User對象
    User user = new User();
    user.setId(rs.getInt("id"));
    user.setName(rs.getString("name"));
    return user;
  }
}

查詢單個對象 <T> T queryForObject(String sql, RowMapper<T> rowMapper, Object... args)
return this.getJdbcTemplate().queryForObject(sql, new UserRowMapper(),id);

 

查詢全部對象List集合 <T> List<T> query(String sql, RowMapper<T> rowMapper, Object... args)
return this.getJdbcTemplate().query(sql, new UserRowMapper());

 

以上提供的方法基本能夠知足咱們的平常須要了。

本文轉自http://www.cnblogs.com/lichenwei/p/3902294.html 感謝做者

相關文章
相關標籤/搜索