2023年全國碩士研究生考試考研英語一試題真題(含答案詳解+作文范文)_第1頁
已閱讀1頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、Spring的JDBCTemplate當(dāng)hql等查詢方式不能滿足性能或靈活性的要求,必須使用SQL時(shí),大家有三種選擇:第一、使用Hibernate的sql查詢函數(shù),將查詢結(jié)果對(duì)象轉(zhuǎn)為Entity對(duì)象。第二、使用HibernateSession的getConnection獲得JDBCConnection,然后進(jìn)行純JDBCAPI操作;第三、選擇把Spring的JDBCTemplate作為一種很不錯(cuò)的JDBCUtils來使用。JDBCTem

2、plate的使用很簡(jiǎn)單,只要在ApplicationContext文件里定義一個(gè)jdbcTemplate節(jié)點(diǎn),POJO獲得注入后可以直接執(zhí)行操作,不需要繼承什么基類,詳見JDBCTemplate參考文檔。AplicationContext定義:實(shí)際使用:SqlRowSetrs=jdbcTemplate.queryFRowSet(sqlparams)Tips1:jdbcTemplate有很多的M化回調(diào)操作將返回結(jié)果轉(zhuǎn)為對(duì)象列表,但很多時(shí)候

3、還是需要返回ResultSet,Spring有提供一個(gè)類似ResultSet的SpringSqlRowSet對(duì)象。Tips2:.注意jdbcTemplate盡量只執(zhí)行查詢操作,莫要進(jìn)行更新,否則很容易破壞Hibernate的二級(jí)緩存體系。Chapter11.使用使用JDBC進(jìn)行數(shù)據(jù)訪問進(jìn)行數(shù)據(jù)訪問11.1.簡(jiǎn)介簡(jiǎn)介SpringJDBC抽象框架所帶來的價(jià)值將在以下幾個(gè)方面得以體現(xiàn):(注:使用了SpringJDBC抽象框架之后,應(yīng)用開發(fā)人員

4、只需要完成斜體字部分的編碼工作。)1.指定數(shù)據(jù)庫連接參數(shù)2.打開數(shù)據(jù)庫連接3.聲明SQL語句4.預(yù)編譯并執(zhí)行SQL語句5.遍歷查詢結(jié)果(如果需要的話)6.處理每一次遍歷操作7.處理拋出的任何異常8.處理事務(wù)9.關(guān)閉數(shù)據(jù)庫連接Spring將替我們完成所有單調(diào)乏味的JDBC底層細(xì)節(jié)處理工作。11.1.1.SpringJDBC包結(jié)構(gòu)包結(jié)構(gòu)NamedParameterJdbcTemplate類增加了在SQL語句中使用命名參數(shù)的支持。在此之前,在

5、傳統(tǒng)的SQL語句中,參數(shù)都是用占位符來表示的。NamedParameterJdbcTemplate類內(nèi)部封裝了一個(gè)普通的JdbcTemplate,并作為其代理來完成大部分工作。下面的內(nèi)容主要針對(duì)NamedParameterJdbcTemplate與JdbcTemplate的不同之處來加以說明,即如何在SQL語句中使用命名參數(shù)。通過下面的例子我們可以更好地了解NamedParameterJdbcTemplate的使用模式(在后面我們還有更

6、好的使用方式)。someJDBCbackedDAOclass...publicintcountOfActsByFirstName(StringfirstName)Stringsql=“count(0)fromT_ACTwherefirst_name=:first_name“NamedParameterJdbcTemplatetemplate=newNamedParameterJdbcTemplate(this.getDataSource

7、())SqlParameterSourcenamedParameters=newMapSqlParameterSource(“first_name“firstName)returntemplate.queryFInt(sqlnamedParameters)在上面例子中,sql變量使用了命名參數(shù)占位符“first_name”,與其對(duì)應(yīng)的值存在namedParameters變量中(類型為MapSqlParameterSource)。如果你喜

8、歡的話,也可以使用基于Map風(fēng)格的名值對(duì)將命名參數(shù)傳遞給NamedParameterJdbcTemplate(NamedParameterJdbcTemplate實(shí)現(xiàn)了NamedParameterJdbcOperations接口,剩下的工作將由調(diào)用該接口的相應(yīng)方法來完成,這里我們就不再贅述):someJDBCbackedDAOclass...publicintcountOfActsByFirstName(StringfirstName)

9、Stringsql=“count(0)fromT_ACTwherefirst_name=:first_name“NamedParameterJdbcTemplatetemplate=newNamedParameterJdbcTemplate(this.getDataSource())MapnamedParameters=newHashMap()namedParameters.put(“first_name“firstName)retur

10、ntemplate.queryFInt(sqlnamedParameters)另外一個(gè)值得一提的特性是與NamedParameterJdbcTemplate位于同一個(gè)包中的SqlParameterSource接口。在前面的代碼片斷中我們已經(jīng)看到了該接口的實(shí)現(xiàn)(即MapSqlParameterSource類),SqlParameterSource可以用來作為NamedParameterJdbcTemplate命名參數(shù)的來源。MapSqlP

11、arameterSource類是一個(gè)非常簡(jiǎn)單的實(shí)現(xiàn),它僅僅是一個(gè)java.util.Map適配器,當(dāng)然其用法也就不言自明了(如果還有不明了的,可以在Spring的JIRA系統(tǒng)中要求提供更多的相關(guān)資料)。SqlParameterSource接口的另一個(gè)實(shí)現(xiàn)--BeanPropertySqlParameterSource為我們提供了更有趣的功能。該類包裝一個(gè)類似JavaBean的對(duì)象,所需要的命名參數(shù)值將由包裝對(duì)象提供,下面我們使用一個(gè)例子

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論