亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

java攻城獅之路--復習JDBC

2019-11-14 20:58:27
字體:
來源:轉載
供稿:網友
java攻城獅之路--復習JDBC1、JDBC中如何獲取數據庫鏈接Connection?

Driver 是一個接口: 數據庫廠商必須提供實現的接口. 能從其中獲取數據庫連接.

可以通過 Driver 的實現類對象獲取數據庫連接.

1. 加入 MySQL 驅動

1). 解壓 mysql-connector-java-5.1.7.zip

2). 在當前項目下新建 lib 目錄

3). 把 mysql-connector-java-5.1.7-bin.jar 復制到 lib 目錄下

4). 右鍵 build-path , add to buildpath 加入到類路徑下.s

幾種常用數據庫的JDBC URL:

@Testpublic void testDriver() throws SQLException {    //1. 創建一個 Driver 實現類的對象    Driver driver = new com.mysql.jdbc.Driver();    //2. 準備連接數據庫的基本信息: url, user, passWord    String url = "jdbc:mysql://localhost:3306/test";    PRoperties info = new Properties();    info.put("user", "root");    info.put("password", "1230");    //3. 調用 Driver 接口的 connect(url, info) 獲取數據庫連接    Connection connection = driver.connect(url, info);    System.out.println(connection);}
獲取數據庫鏈接最簡單方法
/**JDBC.properties文件中的內容:#driver=Oracle.jdbc.driver.OracleDriver#jdbcUrl=jdbc:oracle:thin:@localhost:1521:orcl#user=scott#password=javadriver=com.mysql.jdbc.DriverjdbcUrl=jdbc:mysql://localhost:3306/atguiguuser=rootpassword=1230*/public Connection getConnection() throws Exception{    String driverClass = null;    String jdbcUrl = null;    String user = null;    String password = null;    //讀取類路徑下的 jdbc.properties 文件    InputStream in =             getClass().getClassLoader().getResourceAsStream("jdbc.properties");    Properties properties = new Properties();    properties.load(in);    driverClass = properties.getProperty("driver");    jdbcUrl = properties.getProperty("jdbcUrl");    user = properties.getProperty("user");    password = properties.getProperty("password");    //通過反射常見 Driver 對象.     Driver driver =             (Driver) Class.forName(driverClass).newInstance();    Properties info = new Properties();    info.put("user", user);    info.put("password", password);    //通過 Driver 的 connect 方法獲取數據庫連接.     Connection connection = driver.connect(jdbcUrl, info);    return connection;    }    @Test    public void testGetConnection() throws Exception{        System.out.println(getConnection());    }
在不修改源程序的情況下,獲取任何數據庫鏈接的通用方法(原始方法)

解決方案: 把數據庫驅動 Driver 實現類的全類名、url、user、password 放入一個

配置文件中, 通過修改配置文件的方式實現和具體的數據庫解耦.

    @Test    public void testDriverManager() throws SQLException, IOException {        String driverClass = null;        String jdbcUrl = null;        String user = null;        String password = null;        InputStream in = getClass().getClassLoader().getResourceAsStream(                "jdbc.properties");        Properties proper = new Properties();        proper.load(in);        driverClass = proper.getProperty("driver");        jdbcUrl = proper.getProperty("jdbcUrl");        user = proper.getProperty("user");        password = proper.getProperty("password");        Connection connection = DriverManager.getConnection(jdbcUrl, user,                password);        System.out.println(connection);    }
使用DriverManager獲取數據庫鏈接的方法
    @Test    public void testDriverManager() throws ClassNotFoundException, SQLException {        String driverClass = "com.mysql.jdbc.Driver";        // String driverClass2 = "oracle.jdbc.driver.OracleDriver";        String jdbcUrl = "jdbc:mysql://localhost:3306/test";        // String jdbcUrl2 = "jdbc:oracle:thin:@localhost:1521:orcl";        String user = "root";        // String user2 = "scott";        String password = "123";        // String password2 = "tiger";        Class.forName(driverClass);        Connection connection = DriverManager.getConnection(jdbcUrl, user,                password);        System.out.println(connection);    }
更為簡便的使用DriverManager獲取數據庫鏈接的方法
 1 @Test 2 public void testGetConnection2() throws Exception{ 3         System.out.println(getConnection2());  4 } 5      6 public Connection getConnection2() throws Exception{ 7         //1. 準備連接數據庫的 4 個字符串.  8         //1). 創建 Properties 對象 9         Properties properties = new Properties();10         11         //2). 獲取 jdbc.properties 對應的輸入流12         InputStream in = 13                 this.getClass().getClassLoader().getResourceAsStream("jdbc.properties");14         15         //3). 加載 2) 對應的輸入流16         properties.load(in);17         18         //4). 具體決定 user, password 等4 個字符串. 19         String user = properties.getProperty("user");20         String password = properties.getProperty("password");21         String jdbcUrl = properties.getProperty("jdbcUrl");22         String driver = properties.getProperty("driver");23         24         //2. 加載數據庫驅動程序(對應的 Driver 實現類中有注冊驅動的靜態代碼塊.)25         Class.forName(driver);26         27         //3. 通過 DriverManager 的 getConnection() 方法獲取數據庫連接. 28         return DriverManager.getConnection(jdbcUrl, user, password);29 }
獲取數據庫連接的最終版本,既解耦又利用到了DriverManager

2、如何通過 JDBC 向指定的數據表中插入一條記錄?1. Statement: 用于執行 SQL 語句的對象1). 通過 Connection 的 createStatement() 方法來獲取2). 通過 executeUpdate(sql) 可以執行 SQL 語句.3). 傳入的 SQL 可以是 INSRET, UPDATE 或 DELETE. 但不能是 SELECT2. Connection、Statement 都是應用程序和數據庫服務器的連接資源. 使用后一定要關閉. 需要在 finally 中關閉 Connection 和 Statement 對象. 3. 關閉的順序是: 先關閉后獲取的. 即先關閉 Statement 后關閉 Connection.

    @Test    public void testStatement() throws Exception{        //1. 獲取數據庫連接        Connection conn = null;        Statement statement = null;                try {            conn = getConnection2();                        //3. 準備插入的 SQL 語句            String sql = null;            //            sql = "INSERT INTO customers (NAME, EMAIL, BIRTH) " +//                    "VALUES('XYZ', 'xyz@atguigu.com', '1990-12-12')";//            sql = "DELETE FROM customers WHERE id = 1";            sql = "UPDATE customers SET name = 'TOM' " +                    "WHERE id = 4";            System.out.println(sql);                        //4. 執行插入.             //1). 獲取操作 SQL 語句的 Statement 對象:             //調用 Connection 的 createStatement() 方法來獲取            statement = conn.createStatement();                        //2). 調用 Statement 對象的 executeUpdate(sql) 執行 SQL 語句進行插入            statement.executeUpdate(sql);        } catch (Exception e) {            e.printStackTrace();        } finally{            try {                //5. 關閉 Statement 對象.                if(statement != null)                    statement.close();            } catch (Exception e) {                // TODO Auto-generated catch block                e.printStackTrace();            } finally{                //2. 關閉連接                if(conn != null)                    conn.close();                                        }        }            }
通過Statement獲取連接,執行更新操作(包括insert,update,delete
    public void update(String sql){        Connection conn = null;        Statement statement = null;        String sql = null;        try {            conn = JDBCTools.getConnection();            statement = conn.createStatement();            statement.executeUpdate(sql);        } catch (Exception e) {            e.printStackTrace();        } finally{            JDBCTools.release(statement, conn);        }    }
通用的更新的方法: 包括 INSERT、UPDATE、DELETE(即是要建立一個數據庫工具類:獲取數據庫連接,關閉連接)
package com.shellway.jdbc;import java.io.InputStream;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Properties;/** * 操作 JDBC 的工具類. 其中封裝了一些工具方法 Version 1 */public class JDBCTools {    public static void release(ResultSet rs,             Statement statement, Connection conn) {        if(rs != null){            try {                rs.close();            } catch (SQLException e) {                e.printStackTrace();            }        }                if (statement != null) {            try {                statement.close();            } catch (Exception e2) {                e2.printStackTrace();            }        }        if (conn != null) {            try {                conn.close();            } catch (Exception e2) {                e2.printStackTrace();            }        }    }        /**     * 關閉 Statement 和 Connection     * @param statement     * @param conn     */    public static void release(Statement statement, Connection conn) {        if (statement != null) {            try {                statement.close();            } catch (Exception e2) {                e2.printStackTrace();            }        }        if (conn != null) {            try {                conn.close();            } catch (Exception e2) {                e2.printStackTrace();            }        }    }    /**     * 1. 獲取連接的方法. 通過讀取配置文件從數據庫服務器獲取一個連接.     *      * @return     * @throws Exception     */    public static Connection getConnection() throws Exception {        // 1. 準備連接數據庫的 4 個字符串.        // 1). 創建 Properties 對象        Properties properties = new Properties();        // 2). 獲取 jdbc.properties 對應的輸入流        InputStream in = JDBCTools.class.getClassLoader().getResourceAsStream(                "jdbc.properties");        // 3). 加載 2) 對應的輸入流        properties.load(in);        // 4). 具體決定 user, password 等4 個字符串.        String user = properties.getProperty("user");        String password = properties.getProperty("password");        String jdbcUrl = properties.getProperty("jdbcUrl");        String driver = properties.getProperty("driver");        // 2. 加載數據庫驅動程序(對應的 Driver 實現類中有注冊驅動的靜態代碼塊.)        Class.forName(driver);        // 3. 通過 DriverManager 的 getConnection() 方法獲取數據庫連接.        return DriverManager.getConnection(jdbcUrl, user, password);    }}
附上:要建立的數據庫工具類:JDBCTools

3、總結:

1、Connection:代表應用程序和數據庫的一個連接.

2、Statement:是用于操作 SQL 的對象.

3、ResultSet:封裝 JDBC 的查詢結果.

package com.shellway.jdbc;import java.io.IOException;import java.io.InputStream;import java.security.interfaces.RSAKey;import java.sql.Connection;import java.sql.Date;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;import java.util.Properties;import org.junit.Test;public class ReviewTest {        /**     * 1. ResultSet 封裝 JDBC 的查詢結果.     */    @Test    public void testResultSet(){                Connection connection = null;        Statement statement = null;        ResultSet resultSet = null;                try {            //1. 獲取數據庫連接            connection = getConnection();                        //2. 調用 Connection 對象的 createStatement() 方法獲取 Statement 對象            statement = connection.createStatement();                        //3. 準備 SQL 語句            String sql = "SELECT id, name, email, birth FROM customers";                        //4. 發送 SQL 語句: 調用 Statement 對象的  executeQuery(sql) 方法.            //得到結果集對象 ResultSet            resultSet = statement.executeQuery(sql);                        //5. 處理結果集:            //5.1 調用 ResultSet 的 next() 方法: 查看結果集的下一條記錄是否有效,             //若有效則下移指針            while(resultSet.next()){                //5.2 getXxx() 方法獲取具體的列的值.                 int id = resultSet.getInt(1);                String name = resultSet.getString(2);                String email = resultSet.getString(3);                Date birth = resultSet.getDate(4);                                System.out.println(id);                System.out.println(name);                System.out.println(email);                System.out.println(birth);                                System.out.println();            }                    } catch (Exception e) {            e.printStackTrace();        } finally{            //6. 關閉數據庫資源            releaseDB(resultSet, statement, connection);        }    }        /**     * 1. Statement 是用于操作 SQL 的對象     */    @Test    public void testStatement(){        Connection connection = null;        Statement statement = null;                try {            //1. 獲取數據庫連接            connection = getConnection();                        //2. 調用 Connection 對象的 createStatement() 方法獲取 Statement 對象            statement = connection.createStatement();                        //3. 準備 SQL 語句            String sql = "UPDATE customers SET name = 'Jerry' " +                    "WHERE id = 5";                        //4. 發送 SQL 語句: 調用 Statement 對象的  executeUpdate(sql) 方法            statement.executeUpdate(sql);                    } catch (Exception e) {            e.printStackTrace();        } finally{            //5. 關閉數據庫資源: 由里向外關閉.             releaseDB(null, statement, connection);        }                }        public void releaseDB(ResultSet resultSet, Statement statement,            Connection connection){                if(resultSet != null){            try {                resultSet.close();            } catch (SQLException e) {                e.printStackTrace();            }        }                if(statement != null){            try {                statement.close();            } catch (SQLException e) {                e.printStackTrace();            }        }                if(connection != null){            try {                connection.close();            } catch (SQLException e) {                e.printStackTrace();            }        }    }        @Test    public void testGetConnection2() throws Exception{                Connection connection = getConnection();                System.out.println(connection);     }    public Connection getConnection() throws IOException,            ClassNotFoundException, SQLException {        //0. 讀取 jdbc.properties        /**         * 1). 屬性文件對應 Java 中的 Properties 類         * 2). 可以使用類加載器加載 bin 目錄(類路徑下)的文件         */        Properties properties = new Properties();        InputStream inStream = ReviewTest.class.getClassLoader()                .getResourceAsStream("jdbc.properties");        properties.load(inStream);                //1. 準備獲取連接的 4 個字符串: user, password, jdbcUrl, driverClass        String user = properties.getProperty("user");        String password = properties.getProperty("password");        String jdbcUrl = properties.getProperty("jdbcUrl");        String driverClass = properties.getProperty("driverClass");                //2. 加載驅動: Class.forName(driverClass)        Class.forName(driverClass);                //3. 調用         //DriverManager.getConnection(jdbcUrl, user, password)        //獲取數據庫連接        Connection connection = DriverManager                    .getConnection(jdbcUrl, user, password);        return connection;    }        /**     * Connection 代表應用程序和數據庫的一個連接.     * @throws Exception      */    @Test    public void testGetConnection() throws Exception{        //1. 準備獲取連接的 4 個字符串: user, password, jdbcUrl, driverClass        String user = "root";        String password = "123";        String jdbcUrl = "jdbc:mysql:///test";        String driverClass = "com.mysql.jdbc.Driver";                //2. 加載驅動: Class.forName(driverClass)        Class.forName(driverClass);                //3. 調用         //DriverManager.getConnection(jdbcUrl, user, password)        //獲取數據庫連接        Connection connection = DriverManager                    .getConnection(jdbcUrl, user, password);                System.out.println(connection);     }}
總復習(包括獲取與數據庫的連接Connection,然后創建Statement,最后得到結果集ResultSet)

jdbc.properties文件內容:

user=rootpassword=123driverClass=com.mysql.jdbc.DriverjdbcUrl=jdbc:mysql://localhost:3306/test

#user=scott#password=tiger#driverClass=oracle.jdbc.driver.OracleDriver#jdbcUrl=jdbc:oracle:thin:@127.0.0.1:1521:orcl

吾時而躬身自省,自省使知已之不足,知不足而奮起,未為晚也!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
粉嫩老牛aⅴ一区二区三区| 欧美激情视频网址| 日韩资源在线观看| 欧美激情中文网| 亚洲天堂免费观看| 欧美另类在线播放| 麻豆国产va免费精品高清在线| 亚洲精品国产suv| 亚洲大胆人体在线| 91久久嫩草影院一区二区| 国产精品亚洲自拍| 国内精品视频久久| 国产又爽又黄的激情精品视频| www.99久久热国产日韩欧美.com| 亚洲高清福利视频| 中文字幕亚洲专区| 欧美大片va欧美在线播放| 欧美激情手机在线视频| 国产欧美亚洲视频| 欧美日韩国产丝袜另类| 国产91精品黑色丝袜高跟鞋| 91精品久久久久久久久青青| 亚洲淫片在线视频| 欧美午夜片在线免费观看| 色婷婷**av毛片一区| 久久精品国产亚洲精品| 精品av在线播放| 日韩av手机在线看| 成人午夜小视频| 亚洲精品福利资源站| 国产成人精品综合久久久| 91理论片午午论夜理片久久| 欧美尺度大的性做爰视频| 国产精品9999| 久久久成人的性感天堂| 日韩电影免费在线观看| 91av中文字幕| 亚洲精品美女久久久久| 亚洲精品日韩丝袜精品| 色婷婷久久av| 欧美黄网免费在线观看| 在线日韩中文字幕| 456亚洲影院| 久久久欧美一区二区| 欧美电影免费观看电视剧大全| 91精品国产综合久久香蕉922| 欧美美女15p| 91在线免费视频| 欧美裸身视频免费观看| 1769国内精品视频在线播放| 久久久久久亚洲精品中文字幕| 久久精品视频中文字幕| 国产精品www色诱视频| 日韩专区在线播放| 亚洲欧美日韩精品| 亚洲午夜性刺激影院| 欧美人与性动交| 亚洲国产精品999| 亚洲免费成人av电影| 国产精品自拍网| 久久久久成人精品| 国产精品福利久久久| 亚洲视频在线免费看| 尤物99国产成人精品视频| 国产精品专区h在线观看| 热99精品只有里视频精品| 一区二区国产精品视频| 欧美成人在线免费视频| 国产精品丝袜久久久久久高清| 国产精品永久免费观看| 国产成人午夜视频网址| 久久免费国产视频| 一区二区三区动漫| 欧美疯狂做受xxxx高潮| 欧美专区国产专区| 亚洲白拍色综合图区| 久久久久久九九九| 国产成人一区二区| 国产精品一区二区三区毛片淫片| 久久国产精品电影| 日韩视频免费观看| 91精品国产自产在线| 色综合伊人色综合网站| 色噜噜久久综合伊人一本| 57pao国产精品一区| 成人免费大片黄在线播放| 日本久久91av| 亚洲精品一区中文| 亚洲国产美女久久久久| 国产亚洲精品成人av久久ww| 日韩欧美精品网站| 欧美激情精品久久久| 久久精品色欧美aⅴ一区二区| 久久久精品2019中文字幕神马| 亚洲伊人久久综合| 久久99精品久久久久久青青91| 亚洲www在线观看| 亚洲午夜av电影| 日韩中文在线观看| 久久久伊人日本| 日韩在线高清视频| 在线观看日韩www视频免费| 亚洲国产日韩欧美在线动漫| 欧美一级片一区| 亚洲成人激情视频| 亚洲专区国产精品| 国产精品视频自在线| 久久影视电视剧免费网站| 日韩欧亚中文在线| 国产亚洲欧美一区| 国产+人+亚洲| 色婷婷成人综合| 91久久在线视频| 欧美高清视频在线观看| 91精品国产777在线观看| 亚洲精品久久久久中文字幕二区| 久久久久久久久网站| 国色天香2019中文字幕在线观看| 欧美黑人巨大精品一区二区| 亚洲аv电影天堂网| 欧美成人精品激情在线观看| 欧美日本国产在线| 久久久久中文字幕| 久久久久久国产精品久久| 欧美大成色www永久网站婷| 日韩av片免费在线观看| 国产精品午夜一区二区欲梦| 欧美一级bbbbb性bbbb喷潮片| 色樱桃影院亚洲精品影院| 日本成人在线视频网址| 欧美亚洲免费电影| 日本欧美在线视频| 久久精品国产久精国产思思| 亚洲黄在线观看| 亚洲免费视频在线观看| 最近日韩中文字幕中文| 中文字幕欧美日韩va免费视频| 国产91精品不卡视频| 日韩中文字幕不卡视频| 91色视频在线导航| 国产中文欧美精品| 91九色国产视频| 国内精品久久久久影院优| 亚洲www永久成人夜色| 日韩免费观看av| 亚洲午夜精品久久久久久性色| 精品少妇一区二区30p| 久久的精品视频| 日韩在线国产精品| 色中色综合影院手机版在线观看| 欧美成人在线影院| 国产精品v日韩精品| 久久激情视频久久| 97精品免费视频| 亚洲黄色av网站| 午夜精品久久久久久99热| 欧美日韩精品中文字幕| 中文字幕av一区二区| 欧美极品美女视频网站在线观看免费| 欧美视频免费在线| 国产精品香蕉av| 成人欧美一区二区三区在线| 亚洲精品国精品久久99热| 色噜噜亚洲精品中文字幕|