欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解通過JDBC進行簡單的增刪改查(以MySQL為例)

 更新時間:2017年01月11日 10:05:27   作者:五岳  
JDBC是用于執(zhí)行SQL語句的一類Java API,通過JDBC使得我們可以直接使用Java編程來對關系數據庫進行操作。通過封裝,可以使開發(fā)人員使用純Java API完成SQL的執(zhí)行。

前言:什么是JDBC

Java 數據庫連接,(Java Database Connectivity,簡稱JDBC)是Java語言中用來規(guī)范客戶端程序如何來訪問數據庫的應用程序接口,提供了諸如查詢和更新數據庫中數據的方法。JDBC也是Sun Microsystems的商標。它JDBC是面向關系型數據庫的。

簡單地說,就是用于執(zhí)行SQL語句的一類Java API,通過JDBC使得我們可以直接使用Java編程來對關系數據庫進行操作。通過封裝,可以使開發(fā)人員使用純Java API完成SQL的執(zhí)行。

一、準備工作(一):MySQL安裝配置和基礎學習

使用JDBC操作數據庫之前,首先你需要有一個數據庫。這里提供了3個鏈接供讀者自學,如果曾有過SQL語言的使用經歷(包括在學校中的課堂學習),前兩個鏈接足以上手。

Mysql下載安裝、部署與圖形化詳細操作教程:http://www.dbjr.com.cn/article/87690.htm

建議邊看入門教程,邊練習,在練習insert、update、select、delete等基本操作的同時,將后面要用的表建好。

下圖是我接下來用于演示的數據庫的表。

   

 二、準備工作(二):下載數據庫對應的jar包并導入

使用JDBC需要在工程中導入對應的jar包。數據庫與JDBC包的對應關系可以參考各種數據庫對應的jar包、驅動類名和URL格式。在Eclipse下的導入方法:

在工程的圖標上右擊,選擇”Properties”,在”Java Bulid Path”中選擇”Add External JARs…”,選擇下載并解壓后獲得的jar包。

       

如果對MySQL進行操作,這時下面的import就不會報錯了:

import com.mysql.jdbc.Connection;
import com.mysql.jdbc.PreparedStatement;

除此以外,還需要JDBC的包,直接import即可。

import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;

三、JDBC基本操作

為了簡單起見,與數據庫相關的操作、命令、參數都被硬編碼了。有興趣的讀者可以對這些進行探索,降低數據與操作的耦合性。

先看具體代碼并實踐,本文第五部分對用到的API稍作了研究。

下面的所有方法和數據成員都在public class JDBCOperation內部。

(1)定義記錄的類(可選)

這樣做主要是為了便于操作和接口定義,是非必須的。

static class Student {
  private String Id;
  private String Name;
  private String Sex;
  private String Age;

  Student(String Name, String Sex, String Age) {
   this.Id = null; //default
   this.Name = Name;
   this.Sex = Sex;
   this.Age = Age;
  }

  public String getId() {
   return Id;
  }

  public void setId(String Id) {
   this.Id = Id;
  }

  public String getName() {
   return Name;
  }

  public void setName(String Name) {
   this.Name = Name;
  }

  public String getSex() {
   return Sex;
  }

  public void setSex(String Sex) {
   this.Sex = Sex;
  }

  public String getAge() {
   return Age;
  }

  public void setage(String Age) {
   this.Age = Age;
  }
}

(2)連接的獲取

在操作前必須先獲取與數據庫的連接。

private static Connection getConn() {
 String driver = "com.mysql.jdbc.Driver";
 String url = "jdbc:mysql://localhost:3306/samp_db";
 String username = "root";
 String password = "";
 Connection conn = null;
 try {
  Class.forName(driver); //classLoader,加載對應驅動
  conn = (Connection) DriverManager.getConnection(url, username, password);
 } catch (ClassNotFoundException e) {
  e.printStackTrace();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 return conn;
}

(3)insert

private static int insert(Student student) {
 Connection conn = getConn();
 int i = 0;
 String sql = "insert into students (Name,Sex,Age) values(?,?,?)";
 PreparedStatement pstmt;
 try {
  pstmt = (PreparedStatement) conn.prepareStatement(sql);
  pstmt.setString(1, student.getName());
  pstmt.setString(2, student.getSex());
  pstmt.setString(3, student.getAge());
  i = pstmt.executeUpdate();
  pstmt.close();
  conn.close();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 return i;
}

(4)update

private static int update(Student student) {
 Connection conn = getConn();
 int i = 0;
 String sql = "update students set Age='" + student.getAge() + "' where Name='" + student.getName() + "'";
 PreparedStatement pstmt;
 try {
  pstmt = (PreparedStatement) conn.prepareStatement(sql);
  i = pstmt.executeUpdate();
  System.out.println("resutl: " + i);
  pstmt.close();
  conn.close();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 return i;
}

(5)select

以select * from XXX為例。

private static Integer getAll() {
 Connection conn = getConn();
 String sql = "select * from students";
 PreparedStatement pstmt;
 try {
  pstmt = (PreparedStatement)conn.prepareStatement(sql);
  ResultSet rs = pstmt.executeQuery();
  int col = rs.getMetaData().getColumnCount();
  System.out.println("============================");
  while (rs.next()) {
   for (int i = 1; i <= col; i++) {
    System.out.print(rs.getString(i) + "\t");
    if ((i == 2) && (rs.getString(i).length() < 8)) {
     System.out.print("\t");
    }
    }
   System.out.println("");
  }
   System.out.println("============================");
 } catch (SQLException e) {
  e.printStackTrace();
 }
 return null;
}

(6)delete

private static int delete(String name) {
 Connection conn = getConn();
 int i = 0;
 String sql = "delete from students where Name='" + name + "'";
 PreparedStatement pstmt;
 try {
  pstmt = (PreparedStatement) conn.prepareStatement(sql);
  i = pstmt.executeUpdate();
  System.out.println("resutl: " + i);
  pstmt.close();
  conn.close();
 } catch (SQLException e) {
  e.printStackTrace();
 }
 return i;
}

四、測試

在測試前,需要在系統中打開對應數據庫的服務。MySQL在Windows下的啟動命令為net start mysql

測試代碼

public static void main(String args[]) {
 JDBCOperation.getAll();
 JDBCOperation.insert(new Student("Achilles", "Male", "14"));
 JDBCOperation.getAll();
 JDBCOperation.update(new Student("Bean", "", "7"));
 JDBCOperation.delete("Achilles");
 JDBCOperation.getAll();
}

Eclipse中的輸出

============================
1 Ender  male 8 
2 Bean  male 6 
3 Petra  fema 9 
4 Peter  male 9 
5 _Graff  male 40 
6 GOD  fema 255 
============================
============================
1 Ender  male 8 
2 Bean  male 6 
3 Petra  fema 9 
4 Peter  male 9 
5 _Graff  male 40 
6 GOD  fema 255 
7 Achilles Male 14 
============================
resutl: 1
resutl: 1
============================
1 Ender  male 8 
2 Bean  male 7 
3 Petra  fema 9 
4 Peter  male 9 
5 _Graff  male 40 
6 GOD  fema 255 
============================

五、代碼分析

在上述對數據庫進行增刪改查的過程中,可以發(fā)現其共性部分,即通用的流程:

(1)創(chuàng)建Connection對象、SQL查詢命令字符串;

(2)對Connection對象傳入SQL查詢命令,獲得PreparedStatement對象;

(3)對PreparedStatement對象執(zhí)行executeUpdate()或executeQurey()獲得結果;

(4)先后關閉PreparedStatement對象和Connection對象。

可見,使用JDBC時,最常打交道的是Connection、PreparedStatement這兩個類,以及select中的ResultSet類。

Connection

java.sql

接口 Connection

所有超級接口:Wrapper

--------------------------------------------------------------------------------

public interface Connectionextends Wrapper

與特定數據庫的連接(會話)。在連接上下文中執(zhí)行 SQL 語句并返回結果。

Connection 對象的數據庫能夠提供描述其表、所支持的 SQL 語法、存儲過程、此連接功能等等的信息。此信息是使用 getMetaData 方法獲得的。

PreparedStatemnt

java.sql

接口 PreparedStatement

所有超級接口:Statement, Wrapper所有已知子接口:CallableStatement

--------------------------------------------------------------------------------

public interface PreparedStatementextends Statement

表示預編譯的 SQL 語句的對象。

SQL 語句被預編譯并存儲在 PreparedStatement 對象中。然后可以使用此對象多次高效地執(zhí)行該語句。

常用方法

 boolean execute()

在此 PreparedStatement 對象中執(zhí)行 SQL 語句,該語句可以是任何種類的 SQL 語句。

 ResultSet executeQuery()

在此 PreparedStatement 對象中執(zhí)行 SQL 查詢,并返回該查詢生成的 ResultSet 對象。

 int executeUpdate()

在此 PreparedStatement 對象中執(zhí)行 SQL 語句,該語句必須是一個 SQL 數據操作語言(Data Manipulation Language,DML)語句,比如 INSERT、UPDATE 或 DELETE 語句;或者是無返回內容的 SQL 語句,比如 DDL 語句。

ResultSet

java.sql

接口 ResultSet

所有超級接口:Wrapper所有已知子接口:CachedRowSet, FilteredRowSet, JdbcRowSet, JoinRowSet,RowSet,SyncResolver, WebRowSet

--------------------------------------------------------------------------------

public interface ResultSetextends Wrapper

表示數據庫結果集的數據表,通常通過執(zhí)行查詢數據庫的語句生成?! ?/p>

六、思考問題

1.每次SQL操作都需要建立和關閉連接,這勢必會消耗大量的資源開銷,如何避免?

分析:可以采用連接池,對連接進行統一維護,不必每次都建立和關閉。事實上這是很多對JDBC進行封裝的工具所采用的。

2.Java代碼中,傳入的數據格式與數據庫定義不同怎么辦?如把Java的String對象賦值給數據庫的tinyint屬性。

分析:在執(zhí)行SQL語句時,數據庫會嘗試進行轉換。根據我的實驗,如果用內容為純字母的String對象傳入tinyint的age屬性時,會被轉化成0。具體轉化規(guī)則應該和數據庫有關。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • ArrayList刪除集合中某一屬性相同的元素方法(推薦)

    ArrayList刪除集合中某一屬性相同的元素方法(推薦)

    下面小編就為大家?guī)硪黄狝rrayList刪除集合中某一屬性相同的元素方法(推薦)。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09
  • SpringBoot之返回json數據的實現方法

    SpringBoot之返回json數據的實現方法

    這篇文章主要介紹了SpringBoot之返回json數據的實現方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12
  • java版微信和支付寶退款接口

    java版微信和支付寶退款接口

    這篇文章主要為大家詳細介紹了java版微信退款接口和java版支付寶退款接口,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-09-09
  • Java女裝商城系統的實現流程

    Java女裝商城系統的實現流程

    讀萬卷書不如行萬里路,只學書上的理論是遠遠不夠的,只有在實戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用java+SSM+jsp+mysql+maven實現一個女裝商城系統,大家可以在過程中查缺補漏,提升水平
    2021-11-11
  • 解決springboot配置logback-spring.xml不起作用問題

    解決springboot配置logback-spring.xml不起作用問題

    這篇文章主要介紹了解決springboot配置logback-spring.xml不起作用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Mybatis實現查詢相冊數據列表流程講解

    Mybatis實現查詢相冊數據列表流程講解

    這篇文章主要介紹了Mybatis實現查詢相冊數據列表流程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-12-12
  • 淺談關于Mybatis的mapper-locations配置問題

    淺談關于Mybatis的mapper-locations配置問題

    MyBatis 是一款優(yōu)秀的半自動的ORM持久層框架,它支持自定義 SQL、存儲過程以及高級映射。MyBatis 免除了幾乎所有的 JDBC 代碼以及設置參數和獲取結果集的工作,需要的朋友可以參考下
    2023-05-05
  • java的正則表達式你知道多少

    java的正則表達式你知道多少

    這篇文章主要為大家詳細介紹了java的正則表達式,使用表格進行介紹,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • MyBatis-Plus框架整合詳細方法

    MyBatis-Plus框架整合詳細方法

    MyBatis-Plus是一個 MyBatis 的增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發(fā)、提高效率而生這篇文章主要介紹了MyBatis-Plus框架整合,需要的朋友可以參考下
    2022-04-04
  • 基于Springboot+Junit+Mockito做單元測試的示例

    基于Springboot+Junit+Mockito做單元測試的示例

    本篇文章主要介紹了基于Springboot+Junit+Mockito做單元測試的示例,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02

最新評論