Java學習筆記之_JDBC

來源:互聯網
上載者:User

標籤:

JDBC簡介

  1.SUN公司為了簡化,統一資料庫的操作,定義了一套Java操作資料庫的規範,稱之為JDBC
  2.資料庫驅動
  3.JDBC全稱為:JAVA DataBase Commectivity(java資料庫連接)
  4.組成JDBC的兩個包(1 java.sql,2 javax.sql)。
  5.DriverManager->Connection->Statement(PreparedStatement,CallableStatement)->ResultSet
  6.JavaEE軟體分為了四個層次:
    6.1、用戶端層:DHTML(HTML、CSS、JS)、Java Application
    從第二層開始,位於伺服器端
    6.2、web層(表現層):Servlet/JSP ---- 接收用戶端資料、將資料處理結構展示給用戶端、業務層調度 --- Struts
    6.3、業務層(中介層):EJB ----- 根據系統商務程序 處理用戶端提交資料 --- Spring
    6.4、資料層(持久層):JDBC介面 ------- 完成資料的持久化、從資料庫擷取資料 --- Hibernate/IBatis
    企業裡 web層、業務層、資料層 統稱為三層結構 SSH:Struts+Spring+Hibernate

如何搭建一個JDBC程式

  1.搭建環境
    1.1 在(Mysql,SqlServer,Oracle..)等資料庫中建立一個資料庫和表
    1.2 建立Java工程,並且針對不同的資料庫程式匯入資料庫驅動(maven)
  2.JDBC如何?對資料庫的操作呢?
    2.1 第一步:在程式中裝載驅動
      2.1.1 DriverManager.registerDriver(new com.mysql.jdbc.Driver());
      2.1.2 Class.forName("com.mysql.jdbc.Driver"); //開發中建議使用
    2.2 第二步:獲得資料庫的串連
      String url=""; //資料庫訪問路徑,唯一標示資料庫的位置
      String user=""; //使用者名稱
      String pass=""; //密碼
      Connection conn=DriverManager.getConnection(url,user,pass);
    2.3 第三步:建立用於向資料庫發送Sql的Statement對象,並且發送Sql
      Statement stmt=conn.cteateStatement();
    2.4 第四步: 通過Sql操作資料庫
      String sql="";
      ResultSet rs=stmt.executeQuery(sql); //得到資料結果集
    2.5 第五步:釋放資源
      關閉資源的順序一般為:先開的後關閉,後開的先關閉
      ResultSet->Statement->Connection
  3.讀取設定檔(*.properties)代碼如下:
    ResourceBundle bundle=ResourceBundle.getBundle("*");
    String driver=bundle.getString("driver");

程式詳解—DriverManager

  1.Jdbc程式中的DriverManager用於載入驅動,並建立與資料庫的連結,這個API的常用方法:
    DriverManager.registerDriver(new Driver())
    DriverManager.getConnection(url, user, password),
    備忘:在實際開發中並不推薦採用registerDriver方法註冊驅動。原因有二:
    1.1 查看Driver的原始碼可以看到,如果採用此種方式,會導致驅動程式註冊兩次,也就是在記憶體中會有兩個Driver對象。
    1.2 程式依賴mysql的api,脫離mysql的jar包,程式將無法編譯,將來程式切換底層資料庫將會非常麻煩。
  2. 推薦載入驅動方式:Class.forName(“com.mysql.jdbc.Driver”);
    採用此種方式不會導致驅動對象在記憶體中重複出現,並且採用此種方式,程式僅僅只需要一個字串,不需要依賴具體的驅動,使程式的靈活性更高。
  3. 同樣,在開發中也不建議採用具體的驅動類型指向getConnection方法返回的connection對象。

程式詳解—資料庫URL

  1. URL用於標識資料庫的位置,程式員通過URL地址告訴JDBC程式串連哪個資料庫,URL的寫法為:
    jdbc:mysql://localhost:3306/test?參數名:參數值
    協議 子協議        主機:連接埠     資料庫   參數
  2.常用資料庫URL地址的寫法:
    2.1 Oracle:jdbc:oracle:thin:@localhost:1521:sid
    2.2 SqlServer:jdbc:microsoft:sqlserver://localhost:1433; DatabaseName=sid
    2.3 MySql:jdbc:mysql://localhost:3306/sid
    Mysql的url地址的簡寫形式: jdbc:mysql:///sid
    2.4 常用屬性:useUnicode=true&characterEncoding=UTF-8

程式詳解—Connection

  1. Jdbc程式中的Connection,它用於代表資料庫的連結,Collection是資料庫編程中最重要的一個對象,用戶端與資料庫所有互動都是通過connection對象完成的,這個對象的常用方法:
  createStatement():建立向資料庫發送sql的statement對象
  prepareStatement(sql) :建立向資料庫發送先行編譯sql的PrepareSatement對象
  預存程序
    prepareCall(sql):建立執行預存程序的callableStatement對象。
  事務
    setAutoCommit(boolean autoCommit):設定事務是否自動認可。
    commit() :在連結上提交事務。
    rollback() :在此連結上復原事務

程式詳解-Statement

  1. Jdbc程式中的Statement對象用於向資料庫發送SQL語句, Statement對象常用方法:
  1.1 執行SQL語句
    executeQuery(String sql) :用於向資料發送查詢語句,返回ResultSet結果集
    executeUpdate(String sql):用於向資料庫發送insert、update或delete語句,返回int,受影響的記錄
    execute(String sql):用於向資料庫發送任意sql語句,返回bool
  1.2 支援批處理,一次性執行多條SQL
    addBatch(String sql) :把多條sql語句放到一個批處理中。
    executeBatch():向資料庫發送一批sql語句執行。

程式詳解-PreparedStatement

  1. PreperedStatement是Statement的子類,它的執行個體對象可以通過調用Connection.preparedStatement()方法獲得,相對於Statement對象而言:
  2. PreperedStatement可以避免SQL注入的問題。
  3. Statement會使資料庫頻繁編譯SQL,可能造成資料庫緩衝區溢位。PreparedStatement 可對SQL進行先行編譯,從而提高資料庫的執行效率並且PreperedStatement對於sql中的參數,允許使用預留位置的形式進行替換,簡化sql語句的編寫。
  例如:
    String sql="select * from users where name=? and pwd=?";
    try{
      PreparedStatement pstmt=conn.prepareStatement(sql);
      pstmt.setString(1,userName);
      pstmt.setString(1,password);
      ResultSet rs=pstmt.executeQuery();
    }
  備忘:
    (1). 必須在獲得PrepareStatement對象時,傳入SQL進行先行編譯
    (2). 傳值,索引從1開始
    (3). pstmt執行SQL的時候,一定不要將先行編譯的SQL傳入,否則會出錯

程式詳解-ResultSet

  1. Jdbc程式中的ResultSet用於代表Sql語句的執行結果。Resultset封裝執行結果時,採用的類似於表格的方式。ResultSet 對象維護了一個指向表格式資料行的遊標,初始的時候,遊標在第一行之前,調用ResultSet.next() 方法,可以使遊標指向具體的資料行,進而調用方法擷取該行的資料。
  2.ResultSet既然用於封裝執行結果的,所以該對象提供的大部分方法都是用於擷取資料的get方法:
    2.1 擷取任意類型的資料
      getObject(int index)
      getObject(string columnName)
    2.2 擷取指定類型的資料,例如:
      getString(int index)
      getString(String columnName)
  3. 如果rs返回一行資料,在開發中,經常使用if(rs.next())來替代while(rs.next());
  4. ResultSet還提供了對結果集進行滾動的方法:
    4.1 next():移動到下一行
    4.2 previous():移動到前一行
    4.3 absolute(int row):移動到指定行
    4.4 beforeFirst():移動resultSet的最前面。
    4.5 afterLast() :移動到resultSet的最後面。

程式詳解—釋放資源

  1. Jdbc程式運行完後,切記要釋放程式在運行過程中,建立的那些與資料庫進行互動的對象,這些對象通常是ResultSet, Statement和Connection對象。
  2. 特別是Connection對象,它是非常稀有的資源,用完後必須馬上釋放,如果Connection不能及時、正確的關閉,極易導致系統宕機。Connection的使用原則是盡量晚建立,盡量早的釋放。
  3. 為確保資源釋放代碼能運行,資源釋放代碼也一定要放在finally語句中。

JDBC操作資料庫Demo

  開發環境 MyEclipse
  資料庫 MySql
  :

Java學習筆記之_JDBC

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.