茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    如何處理幾種常見的數據庫不當連接
    來源:易賢網 閱讀:1352 次 日期:2015-09-04 20:32:41
    溫馨提示:易賢網小編為您整理了“如何處理幾種常見的數據庫不當連接”,方便廣大網友查閱!

    基于J2EE平臺的應用開發(fā)中,大多數的應用都需要跟數據庫打交道。而自從接觸JDBC起,我們便不止一次地被告之:數據庫資源是十分寶貴的系統(tǒng)資源,一定要謹慎使用。但令人遺憾的是,在筆者見過的大部分跟數據庫相關的應用開發(fā)中,針對數據庫資源的使用總是充斥著這樣或者那樣的問題。在本文中,筆者對一些常見的錯誤或者不當的使用數據庫資源的案例進行介紹與分析,幫助讀者避免某些錯誤的發(fā)生。

    未正確關閉數據庫連接

    自增長整數型字段賦值表

    申請了數據庫連接,卻沒有及時關閉,這是最常見的數據庫連接使用方面的錯誤。犯這種錯誤的原因很多,以下是常見的一種比較低級的錯誤:

    public void foo() {

    Connection conn=

    getConnection();

    Statement stmt = null;

    try {

    conn=getConnection();

    stmt=conn.createStatement();

    } catch(Exception e) {

    } finally {

    close(stmt, conn);

    }

    }

    在上述案例中的第2行代碼中,作者申請了一個Connection,但在第6行代碼中,又申請了一個新的,并且丟失了第一次申請的Connection的引用。至此,當程序每調一次Foo方法,將導致申請一個新的Connection而沒有釋放它。因此,當數據庫達到最大連接數時,將導致整個應用的運行失敗。

    避免這種錯誤的方法有很多,譬如,可采用類似于FindBugs的代碼分析工具對應用的源碼進行分析,找出可能產生錯誤的代碼。

    此外,在應用中,我們要頻繁地對申請的數據庫連接進行關閉與釋放。此時,建議封裝成某些工具類使用,并且要盡可能安全地關閉數據庫連接。

    任意申請數據庫連接

    不考慮事務上下文,任意申請數據庫連接資源也是常見的不當用法。但這種問題往往是難以克服的,根源在于Java是一種面向對象的語言,而數據庫的事務卻是一種批量化的操作過程。我們以常見的序列號的實現方案為例:在某些應用場景中,我們需要一種自增長的整數型字段。但由于不同的數據庫有不同的實現,所以,為達到各個數據庫兼容的目的,我們常用的解決方案是,新建一張T_SEQUENCE表,它可能包含的字段有:NAME varchar(100), CURRENT_VAL number(10);其中,NAME存放序列的名稱,而CURRENT_VAL存放序列的當前值。假設某一業(yè)務對象Customer需要新增一筆記錄時,為獲得不重復且自增長的Customer ID,需要將T_SEQUENCE表中與該業(yè)務表對應的序列號加1并更新,然后將更新后的值作為Customer的ID。我們以面向對象的3種方法來實現:

    public class Customer {

    /更新序列號使其加1/

    public void sequencePlus(){

    Connection conn=null;

    Statement stmt =null;

    ……//將T_SEQUENCE的序列號當前值加1;

    }

    /獲取當前序列號/

    public int getSequenceCurrentVal(){

    Connection conn=null;

    Statement stmt=null;

    ResultSet rset =null;

    ……// 獲取當前的序列號值;

    }

    /新增一條Customer記錄,自動根據序列號生成主鍵/

    public void addCustomer(String name) {

    Connection conn=null;

    PreparedStatement stmt = null;

    ResultSet rset=null;

    sequencePlus();// 序列號加1;

    int id = getSequenceCurrentVal(); // 得到當前序列號;

    …….// 將最新序列號作為新的T_Customer記錄的主鍵插入;

    }

    }

    針對這種應用場景,我們首先需要認識到:上述3個方法應該屬于同一個數據庫事務。否則,在并發(fā)情況下,將出現由于主鍵重復而導致數據插入失敗的情況。但同時,我們也需要看到:即便上述3個方法的執(zhí)行位于同一個事務中,但3個方法使用的是不同的數據庫連接,雖然在sequencePlus方法中將T_SEQUENCE表中的數據加1 ,但在事務并未提交的情況下,由于Connection隔離級別的原因,在getSequenceCurrentVal方法中,是看不到sequencePlus方法中更新以后的數據的。這樣,也將導致數據插入失敗,因為主鍵勢必跟舊有ID值重復。

    因此,傳統(tǒng)編程方法為克服上述問題,只有在上述的方法中使用同一個Connection,才能夠保證業(yè)務數據的正確。

    更多信息請查看IT技術專欄

    更多信息請查看數據庫

    2026國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
    聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網