欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring?JDBC?框架簡(jiǎn)介

 更新時(shí)間:2021年12月30日 15:08:58   作者:???念卿???  
Spring?JDBC?提供幾種方法和數(shù)據(jù)庫(kù)中相應(yīng)的不同的類(lèi)與接口。我將給出使用JdbcTemplate類(lèi)框架的經(jīng)典和最受歡迎的方法。本文給大家介紹Spring?JDBC?框架的相關(guān)知識(shí),感興趣的朋友一起看看吧

JDBC 框架概述

在使用普通的 JDBC 數(shù)據(jù)庫(kù)時(shí),就會(huì)很麻煩的寫(xiě)不必要的代碼來(lái)處理異常,打開(kāi)和關(guān)閉數(shù)據(jù)庫(kù)連接等。但 Spring JDBC 框架負(fù)責(zé)所有的低層細(xì)節(jié),從開(kāi)始打開(kāi)連接,準(zhǔn)備和執(zhí)行 SQL 語(yǔ)句,處理異常,處理事務(wù),到最后關(guān)閉連接。

所以當(dāng)從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù)時(shí),你所做的是定義連接參數(shù),指定要執(zhí)行的 SQL 語(yǔ)句,每次迭代完成所需的工作。

Spring JDBC 提供幾種方法和數(shù)據(jù)庫(kù)中相應(yīng)的不同的類(lèi)與接口。我將給出使用JdbcTemplate類(lèi)框架的經(jīng)典和最受歡迎的方法。這是管理所有數(shù)據(jù)庫(kù)通信和異常處理的中央框架類(lèi)。

JdbcTemplate 類(lèi)

JdbcTemplate 類(lèi)執(zhí)行 SQL 查詢、更新語(yǔ)句和存儲(chǔ)過(guò)程調(diào)用,執(zhí)行迭代結(jié)果集和提取返回參數(shù)值。它也捕獲 JDBC 異常并轉(zhuǎn)換它們到 org.springframework.dao 包中定義的通用類(lèi)、更多的信息、異常層次結(jié)構(gòu)。

JdbcTemplate類(lèi)的實(shí)例是線程安全配置的。所以你可以配置 JdbcTemplate 的單個(gè)實(shí)例,然后將這個(gè)共享的引用安全地注入到多個(gè) DAOs 中。

使用 JdbcTemplate 類(lèi)時(shí)常見(jiàn)的做法是在你的 Spring 配置文件中配置數(shù)據(jù)源,然后共享數(shù)據(jù)源 bean 依賴注入到 DAO 類(lèi)中,并在數(shù)據(jù)源的設(shè)值函數(shù)中創(chuàng)建了 JdbcTemplate。

配置數(shù)據(jù)源

我們?cè)跀?shù)據(jù)庫(kù)TEST中創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表Student。假設(shè)你正在使用 MySQL 數(shù)據(jù)庫(kù),如果你使用其他數(shù)據(jù)庫(kù),那么你可以改變你的 DDL 和相應(yīng)的 SQL 查詢。

CREATE TABLE Student(
   ID   INT NOT NULL AUTO_INCREMENT,
   NAME VARCHAR(20) NOT NULL,
   AGE  INT NOT NULL,
   PRIMARY KEY (ID)
);

現(xiàn)在,我們需要提供一個(gè)數(shù)據(jù)源到 JdbcTemplate 中,所以它可以配置本身來(lái)獲得數(shù)據(jù)庫(kù)訪問(wèn)。你可以在 XML 文件中配置數(shù)據(jù)源,其中一段代碼如下所示:

<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
   <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
   <property name="url" value="jdbc:mysql://localhost:3306/TEST"/>
   <property name="username" value="root"/>
   <property name="password" value="password"/>
</bean>

數(shù)據(jù)訪問(wèn)對(duì)象(DAO)

DAO 代表常用的數(shù)據(jù)庫(kù)交互的數(shù)據(jù)訪問(wèn)對(duì)象。DAOs 提供一種方法來(lái)讀取數(shù)據(jù)并將數(shù)據(jù)寫(xiě)入到數(shù)據(jù)庫(kù)中,它們應(yīng)該通過(guò)一個(gè)接口顯示此功能,應(yīng)用程序的其余部分將訪問(wèn)它們。

在 Spring 中,數(shù)據(jù)訪問(wèn)對(duì)象(DAO)支持很容易用統(tǒng)一的方法使用數(shù)據(jù)訪問(wèn)技術(shù),如 JDBC、Hibernate、JPA 或者 JDO。

執(zhí)行 SQL 語(yǔ)句

我們看看如何使用 SQL 和 jdbcTemplate 對(duì)象在數(shù)據(jù)庫(kù)表中執(zhí)行 CRUD(創(chuàng)建、讀取、更新和刪除)操作。

查詢一個(gè)整數(shù)類(lèi)型:

String SQL = "select count(*) from Student";
int rowCount = jdbcTemplateObject.queryForInt( SQL );

查詢一個(gè) long 類(lèi)型:

String SQL = "select count(*) from Student";
long rowCount = jdbcTemplateObject.queryForLong( SQL );

一個(gè)使用綁定變量的簡(jiǎn)單查詢:

String SQL = "select age from Student where id = ?";
int age = jdbcTemplateObject.queryForInt(SQL, new Object[]{10});

查詢字符串:

String SQL = "select name from Student where id = ?";
String name = jdbcTemplateObject.queryForObject(SQL, new Object[]{10}, String.class);

查詢并返回一個(gè)對(duì)象:

String SQL = "select * from Student where id = ?";
Student student = jdbcTemplateObject.queryForObject(SQL, 
                  new Object[]{10}, new StudentMapper());
public class StudentMapper implements RowMapper<Student> {
   public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
      Student student = new Student();
      student.setID(rs.getInt("id"));
      student.setName(rs.getString("name"));
      student.setAge(rs.getInt("age"));
      return student;
   }
}

查詢并返回多個(gè)對(duì)象:

String SQL = "select * from Student";
List<Student> students = jdbcTemplateObject.query(SQL,
                         new StudentMapper());
public class StudentMapper implements RowMapper<Student> {
   public Student mapRow(ResultSet rs, int rowNum) throws SQLException {
      Student student = new Student();
      student.setID(rs.getInt("id"));
      student.setName(rs.getString("name"));
      student.setAge(rs.getInt("age"));
      return student;
   }
}

在表中插入一行:

String SQL = "insert into Student (name, age) values (?, ?)";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", 11} );

更新表中的一行:

String SQL = "update Student set name = ? where id = ?";
jdbcTemplateObject.update( SQL, new Object[]{"Zara", 10} );

從表中刪除一行:

String SQL = "delete Student where id = ?";
jdbcTemplateObject.update( SQL, new Object[]{20} );

執(zhí)行 DDL 語(yǔ)句

你可以使用jdbcTemplate中的execute(..)方法來(lái)執(zhí)行任何 SQL 語(yǔ)句或 DDL 語(yǔ)句。下面是一個(gè)使用 CREATE 語(yǔ)句創(chuàng)建一個(gè)表的示例:

String SQL = "CREATE TABLE Student( " +
   "ID   INT NOT NULL AUTO_INCREMENT, " +
   "NAME VARCHAR(20) NOT NULL, " +
   "AGE  INT NOT NULL, " +
   "PRIMARY KEY (ID));"
jdbcTemplateObject.execute( SQL );

Spring JDBC 框架例子

基于上述概念,讓我們看看一些重要的例子來(lái)幫助你理解在 Spring 中使用 JDBC 框架:

到此這篇關(guān)于Spring JDBC 框架的文章就介紹到這了,更多相關(guān)Spring JDBC 框架內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • spring framework源碼調(diào)試技巧

    spring framework源碼調(diào)試技巧

    這篇文章給大家介紹了spring-framework源碼調(diào)試方法,可以直接將最新代碼clone到本地,如果想在代碼做一些注釋?zhuān)部梢訤ork到自己的倉(cāng)庫(kù)。本文采用Fork的方式,并添加了測(cè)試module,感興趣的朋友一起看看吧
    2021-10-10
  • springboot注入servlet的方法

    springboot注入servlet的方法

    本篇文章主要介紹了springboot注入servlet的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • Java中Hashtable類(lèi)與HashMap類(lèi)的區(qū)別詳解

    Java中Hashtable類(lèi)與HashMap類(lèi)的區(qū)別詳解

    Hashtable的應(yīng)用非常廣泛,HashMap是新框架中用來(lái)代替Hashtable的類(lèi),也就是說(shuō)建議使用HashMap,不要使用Hashtable??赡苣阌X(jué)得Hashtable很好用,為什么不用呢?這里簡(jiǎn)單分析他們的區(qū)別。
    2016-01-01
  • SpringBoot+MyBatisPlus中樂(lè)觀鎖的實(shí)現(xiàn)示例

    SpringBoot+MyBatisPlus中樂(lè)觀鎖的實(shí)現(xiàn)示例

    樂(lè)觀鎖是一種用于解決并發(fā)沖突的機(jī)制,在數(shù)據(jù)庫(kù)中用于保護(hù)數(shù)據(jù)的一致性,本文主要介紹了SpringBoot+MyBatisPlus中樂(lè)觀鎖的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-08-08
  • Java隨機(jī)密碼生成并和郵箱、手機(jī)號(hào)匹配

    Java隨機(jī)密碼生成并和郵箱、手機(jī)號(hào)匹配

    這篇文章主要介紹了Java隨機(jī)密碼生成并和郵箱、手機(jī)號(hào)匹配的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • java 進(jìn)制轉(zhuǎn)換實(shí)例詳解

    java 進(jìn)制轉(zhuǎn)換實(shí)例詳解

    這篇文章主要介紹了java 進(jìn)制轉(zhuǎn)換實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • hutool實(shí)戰(zhàn):IoUtil 流操作工具類(lèi)(將內(nèi)容寫(xiě)到流中)

    hutool實(shí)戰(zhàn):IoUtil 流操作工具類(lèi)(將內(nèi)容寫(xiě)到流中)

    這篇文章主要介紹了Go語(yǔ)言的io.ioutil標(biāo)準(zhǔn)庫(kù)使用,是Golang入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下,如果能給你帶來(lái)幫助,請(qǐng)多多關(guān)注腳本之家的其他內(nèi)容
    2021-06-06
  • spring aop實(shí)現(xiàn)用戶權(quán)限管理的示例

    spring aop實(shí)現(xiàn)用戶權(quán)限管理的示例

    本篇文章主要介紹了spring aop實(shí)現(xiàn)用戶權(quán)限管理的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • java線程之死鎖

    java線程之死鎖

    這篇文章主要介紹了Java線程之死鎖,死鎖是這樣一種情形-多個(gè)線程同時(shí)被阻塞,它們中的一個(gè)或者全部都在等待某個(gè)資源被釋放。由于線程被無(wú)限期地阻塞,因此程序不可能正常終止
    2022-05-05
  • Java使用Apache POI操作Excel詳解

    Java使用Apache POI操作Excel詳解

    在Java中操作Excel是日常工作中經(jīng)常遇到的問(wèn)題,而Apache Poi是一種流行且廣泛使用的方式,它提供了各種庫(kù)和工具,所以本文就來(lái)詳細(xì)如何使用Apache Poi來(lái)進(jìn)行Excel文件操作吧
    2023-06-06

最新評(píng)論