亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

使用Spring JDBCTemplate簡化JDBC的操作

2019-11-14 20:49:18
字體:
來源:轉載
供稿:網友
使用SPRing JDBCTemplate簡化JDBC的操作

接觸過java WEB開發的朋友肯定都知道Hibernate框架,雖然不否定它的強大之處,但個人對它一直無感,總感覺不夠靈活,太過臃腫了。

今天來說下Spring中關于JDBC的一個輔助類(JDBC Template),它封裝了JDBC的操作,使用起來非常方便。

先說下"傻瓜式"的使用(不依賴于xml配置):

直接寫個測試單元:

 1 package com.lcw.spring.jdbc; 2  3 import org.junit.Test; 4 import org.springframework.jdbc.core.JdbcTemplate; 5 import org.springframework.jdbc.datasource.DriverManagerDataSource; 6  7 public class JDBCTemplate { 8      9     @Test10     public void demo(){11         DriverManagerDataSource dataSource=new DriverManagerDataSource();12         dataSource.setDriverClassName("com.MySQL.jdbc.Driver");13         dataSource.setUrl("jdbc:mysql:///spring");14         dataSource.setUsername("root");15         dataSource.setPassWord("");16         17         JdbcTemplate jdbcTemplate=new JdbcTemplate(dataSource);18         jdbcTemplate.execute("create table temp(id int primary key,name varchar(32))");19     20     }21 22 }

很簡單吧,再來看下使用結合配置文件,完整的實現對一個類的增刪改查

首先DEMO目錄結構:

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

 1 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)。

1     <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主要提供下列方法:

  1、execute方法:可以用于執行任何SQL語句,一般用于執行DDL語句;

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

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

  4、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 }

怎么樣,很簡單吧,在不缺JDBC里SQL的靈活操作又去除了繁雜操作~

附:

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

用戶自己編寫DAO 只需要繼承 JdbcDaoSupport, 就可以注入 JdbcTemplate

2、 通過jdbcTemplate 提供 int update(String sql, Object... args) 實現增加 、修改 、刪除

3、簡單查詢,返回原始數據類型, 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)

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

編寫實體類 RowMapperclass 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());

以上提供的方法基本可以滿足我們的日常需要了。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人xxxx视频| 亚洲色图综合久久| 国产男女猛烈无遮挡91| 欧美日韩免费一区| 9.1国产丝袜在线观看| 狠狠久久亚洲欧美专区| 国产精彩精品视频| 日韩国产中文字幕| 国产欧美久久久久久| 欧美老女人www| 国产做受69高潮| 国产精品热视频| 久久久精品999| 精品伊人久久97| 狠狠做深爱婷婷久久综合一区| 91美女片黄在线观| 欧美在线精品免播放器视频| 美女精品久久久| 欧美日韩精品中文字幕| 日韩中文视频免费在线观看| 92福利视频午夜1000合集在线观看| 精品视频久久久| 亚洲欧美日韩精品久久奇米色影视| 亚洲欧美日韩爽爽影院| 国产精品美女久久| 久久青草福利网站| 国产精品扒开腿做爽爽爽的视频| 亚洲天堂网在线观看| 久久国产精品免费视频| 亚洲老头同性xxxxx| 91av在线免费观看视频| 亚洲国产成人精品久久| 欧美一级大片在线免费观看| 午夜精品一区二区三区av| 午夜精品www| 色妞色视频一区二区三区四区| 91国产美女视频| 亚洲mm色国产网站| 欧美黄色片视频| 亚洲国产欧美一区二区三区同亚洲| 国内精品中文字幕| 欧美与欧洲交xxxx免费观看| 国产精品主播视频| 亚洲视频专区在线| 国内精品久久久久影院优| 日韩成人性视频| 一道本无吗dⅴd在线播放一区| 韩剧1988免费观看全集| 欧美电影在线免费观看网站| 亚洲剧情一区二区| 日韩在线观看高清| 国产亚洲视频在线| 中文字幕亚洲欧美日韩在线不卡| 国产精品第二页| 日本最新高清不卡中文字幕| 免费91麻豆精品国产自产在线观看| www高清在线视频日韩欧美| 欧美精品videofree1080p| 亚洲天堂av网| 欧美老肥婆性猛交视频| 国产精品亚洲综合天堂夜夜| 日韩欧美精品免费在线| 亚洲国产精彩中文乱码av在线播放| 国产精品一区二区3区| 亚洲国产精品小视频| 欧美大片免费看| 欧美乱大交xxxxx| 国产亚洲精品久久久久久| 久久久黄色av| 日韩av色在线| 黑人巨大精品欧美一区二区三区| 成人免费淫片视频软件| 2020国产精品视频| 青青久久av北条麻妃海外网| 97国产一区二区精品久久呦| 国产成一区二区| 视频一区视频二区国产精品| 久久久在线视频| 狠狠躁夜夜躁人人爽天天天天97| 精品国产1区2区| 性视频1819p久久| 欧美日韩中文字幕日韩欧美| 亚洲新声在线观看| 国产福利精品视频| 色天天综合狠狠色| 中文字幕欧美国内| 欧美一区二区大胆人体摄影专业网站| 色无极影院亚洲| 久久综合88中文色鬼| 91久久精品美女高潮| 日本成人精品在线| 国产精品久久一区主播| 欧美日韩中文字幕在线视频| 91社区国产高清| 国产精品亚洲片夜色在线| 久久精品色欧美aⅴ一区二区| 国产精品极品尤物在线观看| 好吊成人免视频| 亚洲综合在线做性| 亚洲第一综合天堂另类专| 欧美性69xxxx肥| 日韩小视频在线观看| 青草热久免费精品视频| 国产精品视频久久久久| 92看片淫黄大片欧美看国产片| 日本成熟性欧美| 亚洲成年人在线| 亚洲美女自拍视频| 国产999在线观看| 有码中文亚洲精品| 国产精品网址在线| 亚洲精品久久久久中文字幕二区| 国产丝袜高跟一区| 欧美精品福利在线| 国产精品一区电影| 国产91在线高潮白浆在线观看| 成人久久18免费网站图片| 午夜免费在线观看精品视频| 日本久久久久久久久久久| 91精品久久久久久久| 成人国产精品一区二区| 亚洲国产精品国自产拍av秋霞| 第一福利永久视频精品| 久久理论片午夜琪琪电影网| 国产拍精品一二三| 欧美高清视频一区二区| 精品国产福利视频| 国产91在线高潮白浆在线观看| 日韩av电影院| 欧美色播在线播放| 操人视频在线观看欧美| 欧美日韩在线观看视频小说| 九九热精品在线| 亚洲午夜精品久久久久久久久久久久| 97精品久久久| 国产成人在线视频| 亚洲精品自产拍| 91久久精品国产91久久性色| 日本sm极度另类视频| 日韩激情片免费| 狠狠躁夜夜躁人人爽超碰91| 热久久免费国产视频| 欧美精品videos性欧美| 91精品国产91久久久久久吃药| 欧美另类高清videos| 欧美福利视频网站| 最近2019年日本中文免费字幕| 国产午夜精品免费一区二区三区| 欧洲美女免费图片一区| 欧美激情一区二区三区在线视频观看| 日韩成人av在线| 久久影视电视剧免费网站清宫辞电视| 国产91精品最新在线播放| 国产99久久精品一区二区 夜夜躁日日躁| 亚洲一区二区免费在线| 91在线视频免费| 精品国产精品自拍| 国产一区二区三区在线播放免费观看| 亚洲精品综合精品自拍| 国产精品中文在线| 国产精品美腿一区在线看| 4438全国亚洲精品在线观看视频| 伊人久久精品视频| 日韩中文理论片|