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

Spring 中jdbcTemplate 實(shí)現(xiàn)執(zhí)行多條sql語(yǔ)句示例

 更新時(shí)間:2017年01月14日 14:58:47   作者:菜鳥寶寶  
本篇文章主要介紹了Spring 中jdbcTemplate 實(shí)現(xiàn)執(zhí)行多條sql語(yǔ)句示例,可以對(duì)多個(gè)表執(zhí)行多個(gè)sql語(yǔ)句,有興趣的可以了解一下。

說(shuō)一下Spring框架中使用jdbcTemplate實(shí)現(xiàn)多條sql語(yǔ)句的執(zhí)行:

很多情況下我們需要處理一件事情的時(shí)候需要對(duì)多個(gè)表執(zhí)行多個(gè)sql語(yǔ)句,比如淘寶下單時(shí),我們確認(rèn)付款時(shí)要對(duì)自己銀行賬戶的表里減去訂單所需的錢數(shù),即需要更新銀行賬戶的表,同時(shí)需要更新淘寶訂單的表將訂單狀態(tài)改為“已付款”,這就需要先后執(zhí)行多個(gè)sql(僅僅用于表達(dá)執(zhí)行多的SQL的舉例說(shuō)明,具體淘寶如何實(shí)現(xiàn)并不是很清楚~~~~~); 但如果這中間出現(xiàn)電腦斷網(wǎng)斷電等問(wèn)題,僅將我們銀行賬戶的錢扣掉了,訂單狀態(tài)并沒(méi)有改,那我們是不是很慘,但實(shí)際上我們并沒(méi)有遇到這種情況對(duì)吧,下面我就來(lái)講一下如何使用Spring 中jdbcTemplate 實(shí)現(xiàn)執(zhí)行多條sql語(yǔ)句,而不出現(xiàn)這種情況

@Test  
public void 權(quán)限分配(){
    //1.客戶端復(fù)選框傳遞過(guò)來(lái)一個(gè)數(shù)組1,2 菜單的ID
    Integer[] menus =new Integer[]{1,2};
    //2.聲明sql數(shù)組
    String [] sql =new String [menus.length+1];
    //3.通過(guò)Role_id 200 刪除表中數(shù)據(jù)
    sql[0] = "delete from role_link_menu where fk_role_id=200";
    //4新數(shù)據(jù)添加到中間表
    for (int i=0;i<menus.length;i++) {
      sql[i+1]="insert into role_link_menu(id,fk_role_id,fk_menu_id) values ('"+UUID.randomUUID().toString()+"',200,             "+menus[i]+")";
    }
    jdbcTemplate.batchUpdate(sql);
  }

前提我們已經(jīng)連接好數(shù)據(jù)庫(kù)

這樣我們一共執(zhí)行了3條SQL語(yǔ)句

1.delete from role_link_menu where fk_role_id=200

2.insert into role_link_menu(id,fk_role_id,fk_menu_id) values ('"+UUID.randomUUID().toString()+"',200,1")";

3.insert into role_link_menu(id,fk_role_id,fk_menu_id) values ('"+UUID.randomUUID().toString()+"',200,2")";

這期間任一條SQL語(yǔ)句出現(xiàn)問(wèn)題都會(huì)回滾[**]會(huì)所有語(yǔ)句沒(méi)有執(zhí)行前的最初狀態(tài)^_^

對(duì)比下面一組代碼,我們就可以發(fā)現(xiàn)其中不同

@Test
  public void 權(quán)限分配單個(gè)處理() throws Exception{
    //1.通過(guò)Role_id 200 刪除表中數(shù)據(jù)
    String sql = "delect from role_link_menu where fk_role_id=200";
    jdbcTemplate.update(sql);
    //2.客戶端復(fù)選框傳遞過(guò)來(lái)一個(gè)數(shù)組1,2 菜單的id
    Integer[] menus =new Integer[]{1,2};
    //3.新數(shù)據(jù)添加到中間表
    for (int i=0;i<menus.length;i++) {
      String menu_sql="insert into role_link_menu(id,fk_role_id,fk_menu_id) values ('"+UUID.randomUUID().toString()+           "',200,"+menus[i]+")";
      if(i==1){
        throw new Exception("=====");
      }
      jdbcTemplate.update(menu_sql);
    }
  }

這里當(dāng)i=1會(huì)出現(xiàn)異常程序終止,共執(zhí)行了2條語(yǔ)句

1.delect from role_link_menu where fk_role_id=200

2.insert into role_link_menu(id,fk_role_id,fk_menu_id) values ('"+UUID.randomUUID().toString()+ "',200,1)";

下面一句不會(huì)執(zhí)行,但之前這兩條執(zhí)行完畢,就相當(dāng)于本來(lái)我們要買啤酒喝炸雞,賬戶錢扣了,結(jié)果就只給了你一罐啤酒,是不是郁悶?zāi)?,啊哈,反正我不?huì)開心

滴~~~ 

**注:

回滾:事務(wù)是一組組合成邏輯工作單元的操作,雖然系統(tǒng)中可能會(huì)出錯(cuò),但事務(wù)將控制和維護(hù)事務(wù)中每個(gè)操作的一致性和完整性。

例如,在將資金從一個(gè)帳戶轉(zhuǎn)移到另一個(gè)帳戶的銀行應(yīng)用中,一個(gè)帳戶將一定的金額貸記到一個(gè)數(shù)據(jù)庫(kù)表中,同時(shí)另一個(gè)帳戶將相同的金額借記到另一個(gè)數(shù)據(jù)庫(kù)表中。由于計(jì)算機(jī)可能會(huì)因停電、網(wǎng)絡(luò)中斷等而出現(xiàn)故障,因此有可能更新了一個(gè)表中的行,但沒(méi)有更新另一個(gè)表中的行。

如果數(shù)據(jù)庫(kù)支持事務(wù),則可以將數(shù)據(jù)庫(kù)操作組成一個(gè)事務(wù),以防止因這些事件而使數(shù)據(jù)庫(kù)出現(xiàn)不一致。如果事務(wù)中的某個(gè)點(diǎn)發(fā)生故障,則所有更新都可以回滾到事務(wù)開始之前的狀態(tài)。如果沒(méi)有發(fā)生故障,則通過(guò)以完成狀態(tài)提交事務(wù)來(lái)完成更新。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論