搜尋
首頁Javajava教程java 中JDBC連接資料庫和步驟詳解及實例

java 中JDBC連接資料庫程式碼與步驟詳解

JDBC連接資料庫  

•建立一個以JDBC連接資料庫的程序,包含7個步驟:   

 1、載入JDBC驅動程式:   

    在連接資料庫之前,首先要載入想要連接的資料庫的驅動到JVM(Java虛擬機器),這透過java.lang.Class類別的靜態方法forName(String  className)實作。

    例如:   


#
  try{  
  //加载MySql的驱动类  
  Class.forName("com.mysql.jdbc.Driver") ;  
  }catch(ClassNotFoundException e){  
  System.out.println("找不到驱动程序类 ,加载驱动失败!");  
  e.printStackTrace() ;  
  }


   成功載入後,會將Driver類別的執行個體註冊到DriverManager類別中。   

 2、提供JDBC連線的URL   

##   •連接URL定義了連接資料庫時的協定、子協定、資料來源識別碼。

   •書寫形式:協定:子協定:資料源識別   

#    協定:在JDBC中總是以jdbc開始    

  是資料庫管理系統名稱。   


    資料來源識別:標記找到資料庫來源的位址與連接埠。


    例如:(MySql的連接URL)   



 jdbc:mysql:  
    //localhost:3306/test?useUnicode=true&characterEncoding=gbk ;


   useUnicode=true:表示使用Unicode字符集。如果characterEncoding設定為   


   gb2312或GBK,本參數必須設定為true 。 characterEncoding=gbk:字元編碼方式。


 3、建立資料庫的連線   

    •要連接資料庫,需要向java.sql.DriverManager請求並取得Connection對象,該對象就代表一個資料庫的連線。  

    •使用DriverManager的getConnectin(String url , String username ,    String password )方法傳入指定的想要連接的資料庫的路徑、資料庫的使用者名稱和   

 


     例如:   


//连接MySql数据库,用户名和密码都是root  
   String url = "jdbc:mysql://localhost:3306/test" ;  
   String username = "root" ;  
   String password = "root" ;  
   try{  
  Connection con =  
       DriverManager.getConnection(url , username , password ) ;  
   }catch(SQLException se){  
  System.out.println("数据库连接失败!");  
  se.printStackTrace() ;  
   }


 4、創建一個Statement   


    •要執行SQL語句,必須取得java.sql.Statement實例,Statement實例分為以下3  種類型:   


#      1、執行靜態語句。通常透過Statement實例實現。  

      2、執行動態SQL語句。通常透過PreparedStatement實例實現。  

      3、執行資料庫預存程序。通常透過CallableStatement實例實現。


    特定的實作方式:           

Statement stmt = con.createStatement() ;  
    PreparedStatement pstmt = con.prepareStatement(sql) ;  
    CallableStatement cstmt =  
              con.prepareCall("{CALL demoSp(? , ?)}") ;


##    Statement介面提供了三種執行SQL語句的方法:executeQuery 、executeUpdate 和execute   

    1、ResultSet executeQuery(


    1、ResultSetSet executeQuery(

   
        ,並回傳一個結果集(ResultSet)物件。
     2、int executeUpdate(String sqlString):用於執行INSERT、UPDATE或  
        DELETE語句以及SQL DDL語句,如: 傳回多個結果集、多個更新計數或二者組合的   語句。

   實作的程式碼:   



     ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ;  
  int rows = stmt.executeUpdate("INSERT INTO ...") ;  
  boolean flag = stmt.execute(String sql) ;


 6、處理結果   

    兩種情況:   


#     1.執行更新回傳的是此操作影響到的記錄數。  

     2、執行查詢回傳的結果是一個ResultSet物件。   

    • ResultSet包含所有符合SQL語句中條件的資料行,且它透過一套get方法提供了這些 行中資料的存取。

    • 使用結果集(ResultSet)物件的存取方法取得資料:     


  while(rs.next()){  
     String name = rs.getString("name") ;  
  String pass = rs.getString(1) ; // 此方法比较高效  
   }


#   (列是從左到右編號的,並且從列1開始)   


 7、关闭JDBC对象    

     操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声  明顺序相反:   

     1、关闭记录集  
     2、关闭声明  
     3、关闭连接对象   


     if(rs != null){  // 关闭记录集  
    try{  
      rs.close() ;  
    }catch(SQLException e){  
      e.printStackTrace() ;  
    }  
     }  
     if(stmt != null){  // 关闭声明  
    try{  
      stmt.close() ;  
    }catch(SQLException e){  
      e.printStackTrace() ;  
    }  
     }  
     if(conn != null){ // 关闭连接对象  
     try{  
      conn.close() ;  
     }catch(SQLException e){  
      e.printStackTrace() ;  
     }  
     }


感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

更多java 中JDBC连接数据库和步骤详解及实例相关文章请关注PHP中文网!


陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版