您好,登錄后才能下訂單哦!
這篇文章主要介紹了jdbcTemplate使用方法實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
Spring JDBC抽象框架core包提供了JDBC模板類,其中JdbcTemplate是core包的核心類,所以其他模板類都是基于它封裝完成的,JDBC模板類是第一種工作模式。
JdbcTemplate類通過模板設(shè)計(jì)模式幫助我們消除了冗長的代碼,只做需要做的事情(即可變部分),并且?guī)臀覀冏瞿男┕潭ú糠郑邕B接的創(chuàng)建及關(guān)閉。
在application-mybatis.xml中配置的DataSource注入到JdbcTemplate中,就可以使用JdbcTemplate模板了
配置文件中加入以下內(nèi)容:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${jdbc.driverClassName}"/><!--加載驅(qū)動--> <property name="url" value="${jdbc.url}"/><!--數(shù)據(jù)庫的位置--> <property name="username" value="${jdbc.username}"/><!--數(shù)據(jù)庫的用戶名--> <property name="password" value="${jdbc.password}"/><!--對應(yīng)的密碼--> <property name="maxActive" value="50"/><!--連接池的最大活動數(shù)--> <property name="minIdle" value="5"/><!--最少保持5條空閑連接--> <property name="maxWait" value="5000"/><!--等待時(shí)間5秒--> </bean>
java文件:
@Autowired @Qualifier("dataSource") public DataSource dataSource; public JdbcTemplate getJdbcTemplate(){ JdbcTemplate jdbcTemplate = new JdbcTemplate(this.dataSource); return jdbcTemplate; }
此時(shí)jdbcTemplate變量中便會有相關(guān)的數(shù)據(jù)庫的基本參數(shù)配置信息,
jdbcTemplate類型中有如下方法
JdbcTemplate主要提供以下五類方法:
execute方法:可以用于執(zhí)行任何SQL語句,一般用于執(zhí)行DDL語句;
update方法及batchUpdate方法:update方法用于執(zhí)行新增、修改、刪除等語句;batchUpdate方法用于執(zhí)行批處理相關(guān)語句;
query方法及queryForXXX方法:用于執(zhí)行查詢相關(guān)語句;
//1.查詢一行數(shù)據(jù)并返回int型結(jié)果 jdbcTemplate.queryForInt("select count(*) from test"); //2. 查詢一行數(shù)據(jù)并將該行數(shù)據(jù)轉(zhuǎn)換為Map返回 jdbcTemplate.queryForMap("select * from test where name='name5'"); //3.查詢一行任何類型的數(shù)據(jù),最后一個(gè)參數(shù)指定返回結(jié)果類型 jdbcTemplate.queryForObject("select count(*) from test", Integer.class); //4.查詢一批數(shù)據(jù),默認(rèn)將每行數(shù)據(jù)轉(zhuǎn)換為Map jdbcTemplate.queryForList("select * from test"); //5.只查詢一列數(shù)據(jù)列表,列類型是String類型,列名字是name jdbcTemplate.queryForList(" select name from test where name=?", new Object[]{"name5"}, String.class); //6.查詢一批數(shù)據(jù),返回為SqlRowSet,類似于ResultSet,但不再綁定到連接上 SqlRowSet rs = jdbcTemplate.queryForRowSet("select * from test");
call方法:用于執(zhí)行存儲過程、函數(shù)相關(guān)語句。
支持的回調(diào)接口如下:
JdbcTemplate類支持的回調(diào)類:
預(yù)編譯語句及存儲過程創(chuàng)建回調(diào):用于根據(jù)JdbcTemplate提供的連接創(chuàng)建相應(yīng)的語句;
PreparedStatementCreator:通過回調(diào)獲取JdbcTemplate提供的Connection,由用戶使用該Conncetion創(chuàng)建相關(guān)的PreparedStatement;
CallableStatementCreator:通過回調(diào)獲取JdbcTemplate提供的Connection,由用戶使用該Conncetion創(chuàng)建相關(guān)的CallableStatement;
預(yù)編譯語句設(shè)值回調(diào):用于給預(yù)編譯語句相應(yīng)參數(shù)設(shè)值;
PreparedStatementSetter:通過回調(diào)獲取JdbcTemplate提供的PreparedStatement,由用戶來對相應(yīng)的預(yù)編譯語句相應(yīng)參數(shù)設(shè)值;
BatchPreparedStatementSetter:;類似于PreparedStatementSetter,但用于批處理,需要指定批處理大小;
自定義功能回調(diào):提供給用戶一個(gè)擴(kuò)展點(diǎn),用戶可以在指定類型的擴(kuò)展點(diǎn)執(zhí)行任何數(shù)量需要的操作;
ConnectionCallback:通過回調(diào)獲取JdbcTemplate提供的Connection,用戶可在該Connection執(zhí)行任何數(shù)量的操作;
StatementCallback:通過回調(diào)獲取JdbcTemplate提供的Statement,用戶可以在該Statement執(zhí)行任何數(shù)量的操作;
PreparedStatementCallback:通過回調(diào)獲取JdbcTemplate提供的PreparedStatement,用戶可以在該P(yáng)reparedStatement執(zhí)行任何數(shù)量的操作;
CallableStatementCallback:通過回調(diào)獲取JdbcTemplate提供的CallableStatement,用戶可以在該CallableStatement執(zhí)行任何數(shù)量的操作;
結(jié)果集處理回調(diào):通過回調(diào)處理ResultSet或?qū)esultSet轉(zhuǎn)換為需要的形式;
RowMapper:用于將結(jié)果集每行數(shù)據(jù)轉(zhuǎn)換為需要的類型,用戶需實(shí)現(xiàn)方法mapRow(ResultSet rs, int rowNum)來完成將每行數(shù)據(jù)轉(zhuǎn)換為相應(yīng)的類型。
RowCallbackHandler:用于處理ResultSet的每一行結(jié)果,用戶需實(shí)現(xiàn)方法processRow(ResultSet rs)來完成處理,在該回調(diào)方法中無需執(zhí)行rs.next(),該操作由JdbcTemplate來執(zhí)行,用戶只需按行獲取數(shù)據(jù)然后處理即可。
ResultSetExtractor:用于結(jié)果集數(shù)據(jù)提取,用戶需實(shí)現(xiàn)方法extractData(ResultSet rs)來處理結(jié)果集,用戶必須處理整個(gè)結(jié)果集;
JdbcTemplate執(zhí)行流程:首先定義SQL,其次調(diào)用JdbcTemplate方法執(zhí)行SQL,最后通過RowCallbackHandler回調(diào)處理ResultSet結(jié)果集。
Spring JDBC解決方法相比傳統(tǒng)JDBC編程方式簡單多了,只有可變部分需要我們來做,其他的都由Spring JDBC框架來實(shí)現(xiàn)了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。