中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jdbc連接數據庫實例詳解

發布時間:2020-10-01 07:34:54 來源:腳本之家 閱讀:145 作者:laozhang 欄目:編程語言

JDBC簡介

JDBC全稱為:Java Data Base Connectivity (java數據庫連接),可以為多種數據庫提供填統一的訪問。JDBC是sun開發的一套數據庫訪問編程接口,是一種SQL級的API。它是由java語言編寫完成,所以具有很好的跨平臺特性,使用JDBC編寫的數據庫應用程序可以在任何支持java的平臺上運行,而不必在不同的平臺上編寫不同的應用程序。

JDBC編程步驟

(1)加載驅動程序:

下載驅動包 : http://dev.mysql.com/downloads/connector/j/

解壓,得到 jar文件。將該文件復制到Java工程目錄Java Resources/Libraries/ 下,→ buildpath 。

(2)獲得數據庫連接

(3)創建Statement對象:

(4)向數據庫發送SQL命令

(5)處理數據庫的返回結果(ResultSet類)

package com.baidu.emp.jdbcTest;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
 
import com.mysql.jdbc.Driver;
/**
 * 開始使用jdbc連接數據庫
 * @author Admin
 *
 */
public class Test001 {
 
  public static void main(String[] args) throws Exception {
 
    /**
     * 加載驅動
     */
    // 方法一:
    /*
     * import java.sql.DriverManager; import com.mysql.jdbc.Driver;
     */
    // Driver driver = new Driver();
    // DriverManager.registerDriver(driver);
 
    // 方法二:(推薦使用)
    Class.forName("com.mysql.jdbc.Driver");
 
    /**
     * 創建鏈接
     */
    String url = "jdbc:mysql://localhost:3306/testjdbc";
    String user = "root";
    String password = "root";
    Connection connection = DriverManager.getConnection(url, user, password);
 
    // 創建statement對象
    Statement statement = connection.createStatement();
 
    /**
     * 執行SQL,獲取結果集
     */
    String sql = "select * from test01";
    ResultSet result = statement.executeQuery(sql);
 
    // 遍歷結果集
    while (result.next()) {
      String name = result.getString("name");
      int id = result.getInt("id");
      System.out.println(name + "\t" + id);
    }
 
    /**
     * 關閉鏈接,釋放資源
     */
    result.close();
    statement.close();
    connection.close();
  }
}

防止SQL注入改用prepareStatement

package com.boya.emp.jdbcTest;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
/**
 * SQL注入,使用prepareStatement對象進行預編譯
 * @author Admin
 *
 */
public class Test002 {
 
  public static void main(String[] args) throws Exception {
 
    /**
     * 加載驅動
     */
    Class.forName("com.mysql.jdbc.Driver");
 
    /**
     * 創建鏈接
     */
    String url = "jdbc:mysql://localhost:3306/testjdbc";
    String user = "root";
    String password = "root";
    Connection connection = DriverManager.getConnection(url, user, password);
 
    // 寫SQL 
    String sql = "select * from test01 where id = ?";
    //創建statement對象,預編譯
    PreparedStatement statement = connection.prepareStatement(sql);
    //設置參數
    statement.setInt(1, 2);
    /**
     * 執行SQL,獲取結果集
     */
    ResultSet result = statement.executeQuery();
 
    // 遍歷結果集
    while (result.next()) {
      String name = result.getString("name");
      int id = result.getInt("id");
      System.out.println(name + "\t" + id);
    }
 
    /**
     * 關閉鏈接,釋放資源
     */
    result.close();
    statement.close();
    connection.close();
  }
}

進行代碼優化,設置配置文件,工具類,實現增刪該查

增加配置文件方便修改數據庫,用戶登錄。。。

jdbc.properties(配置文件名)

driverName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/testjdbc
userName=root
password=root

注意寫配置文件時中間不可以有空格,引號之類的

工具類:增強了代碼的復用性

package com.baidu.emp.utils;
 
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;
 
import org.junit.Test;
 
 
 
public class JdbcUtils {
 
  static String driverClassName;
  static String url;
  static String user;
  static String password;
 
  static {
    // 創建配置文件對象
    Properties properties = new Properties();
    // 加載配置文件輸入流
    InputStream inputStream = JdbcUtils.class.getClassLoader().getResourceAsStream("jdbc.properties");
    // 重新加載配置文件
    try {
      properties.load(inputStream);
      // 獲取配置文件的值
      driverClassName = properties.getProperty("driverName");
      url = properties.getProperty("url");
      user = properties.getProperty("userName");
      password = properties.getProperty("password");
      Class.forName(driverClassName);
 
    } catch (Exception e) {
      // 拋出異常
      throw new RuntimeException(e);
    }
  }
 
  /**
   * 獲取連接
   */
  @Test
  public void testName() throws Exception {
     
    System.out.println(driverClassName);
  }
  public static Connection getConnection() {
    Connection connection = null;
    try {
      connection = DriverManager.getConnection(url, user, password);
    } catch (SQLException e) {
      // 拋出異常
      throw new RuntimeException(e);
    }
    return connection;
  }
 
  /**
   * 關閉鏈接,釋放資源
   */
  public static void close(Connection connection, PreparedStatement statement, ResultSet resultSet) {
 
    try {
      if (resultSet != null) {
        resultSet.close();
      }
      resultSet = null; // 垃圾及時清除
      //注意,不要弄成死循環
      close(connection, statement);
    } catch (SQLException e) {
      throw new RuntimeException(e);
    }
 
  }
 
  /**
   * 增刪改釋放資源
   */
  public static void close(Connection connection, PreparedStatement statement) {
 
    try {
      if (connection != null) {
        connection.close();
      }
         
      connection = null;
      if (statement != null) {
        statement.close();
      }
      statement = null;
 
    } catch (SQLException e) {
      throw new RuntimeException(e);
    }
 
  }
 
}

測試增刪改查:

package com.baidu.emp.jdbcTest;
 
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
 
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
 
import com.baidu.emp.utils.JdbcUtils;
 
/**
 * 使用jdbcUtils連接數據庫進行增刪改查
 * 
 * @author Admin
 *
 */
public class Test003 {
 
  // 初始化值
  Connection connection = null;
  PreparedStatement statement = null;
  ResultSet result = null;
 
  @Before
  public void start() throws Exception {
    // 創建鏈接
    connection = JdbcUtils.getConnection();
    System.out.println("創建鏈接");
  }
 
  @After
  public void end() throws Exception {
    // 關閉鏈接
    JdbcUtils.close(connection, statement, result);
    System.out.println("關閉鏈接");
  }
   
  /**
   *插入數據
   * @throws Exception
   */
  @Test
  public void add() throws Exception {
    String sql = "insert into test01 values(null,?)";
    statement = connection.prepareStatement(sql);
    statement.setString(1, "李四");
    int result = statement.executeUpdate();
    if (result!=0) {
      System.out.println("添加成功");
    }
  }
  /**
   * 刪除數據
   * @throws Exception
   */
  @Test
  public void del() throws Exception {
    String sql = "delete from test01 where id =?";
    statement = connection.prepareStatement(sql);
    statement.setInt(1,3);
    int result = statement.executeUpdate();
    if (result!=0) {
      System.out.println("刪除成功");
    }
  }
  /**
   * 修改數據
   * @throws Exception
   */
  @Test
  public void change() throws Exception {
    String sql = "update test01 set name = ? where id = ?";
    statement = connection.prepareStatement(sql);
    statement.setString(1, "張飛");
    statement.setInt(2, 2);
    int result = statement.executeUpdate();
    if (result!=0) {
      System.out.println("修改成功");
    }
  }
   
  /**
   * 查詢全部數據
   * @throws Exception
   */
  @Test
  public void findAll() throws Exception {
    String sql = "select id , name from test01";
    statement = connection.prepareStatement(sql);
    result = statement.executeQuery();
    if (result.next()) {
      System.out.println("查詢成功");
    }
  }
   
  /**
   * 條件查詢數據
   * @throws Exception
   */
  @Test
  public void findOne() throws Exception {
    String sql = "select id , name from test01 where id = ?";
    statement = connection.prepareStatement(sql);
    statement.setInt(1, 2);
    result = statement.executeQuery();
    if (result.next()) {
      System.out.println("查詢成功");
    }
  }
 
}

以上就是相關知識以及相關代碼,感謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

寿宁县| 肃北| 棋牌| 临夏县| 玉环县| 平武县| 清远市| 惠东县| 泽库县| 浑源县| 获嘉县| 枣阳市| 五原县| 洞口县| 南木林县| 会泽县| 延寿县| 昭通市| 九江市| 莱州市| 兴海县| 苗栗市| 体育| 阜城县| 曲阳县| 鹿泉市| 抚松县| 寿阳县| 涪陵区| 苍南县| 永嘉县| 库尔勒市| 鄂温| 云梦县| 舟曲县| 平乐县| 浦东新区| 南汇区| 渭南市| 明溪县| 玉田县|