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

詳解通過(guò)JDBC進(jìn)行簡(jiǎn)單的增刪改查(以MySQL為例)

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

前言:什么是JDBC

Java 數(shù)據(jù)庫(kù)連接,(Java Database Connectivity,簡(jiǎn)稱JDBC)是Java語(yǔ)言中用來(lái)規(guī)范客戶端程序如何來(lái)訪問(wèn)數(shù)據(jù)庫(kù)的應(yīng)用程序接口,提供了諸如查詢和更新數(shù)據(jù)庫(kù)中數(shù)據(jù)的方法。JDBC也是Sun Microsystems的商標(biāo)。它JDBC是面向關(guān)系型數(shù)據(jù)庫(kù)的。

簡(jiǎn)單地說(shuō),就是用于執(zhí)行SQL語(yǔ)句的一類Java API,通過(guò)JDBC使得我們可以直接使用Java編程來(lái)對(duì)關(guān)系數(shù)據(jù)庫(kù)進(jìn)行操作。通過(guò)封裝,可以使開(kāi)發(fā)人員使用純Java API完成SQL的執(zhí)行。

一、準(zhǔn)備工作(一):MySQL安裝配置和基礎(chǔ)學(xué)習(xí)

使用JDBC操作數(shù)據(jù)庫(kù)之前,首先你需要有一個(gè)數(shù)據(jù)庫(kù)。這里提供了3個(gè)鏈接供讀者自學(xué),如果曾有過(guò)SQL語(yǔ)言的使用經(jīng)歷(包括在學(xué)校中的課堂學(xué)習(xí)),前兩個(gè)鏈接足以上手。

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

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

下圖是我接下來(lái)用于演示的數(shù)據(jù)庫(kù)的表。

   

 二、準(zhǔn)備工作(二):下載數(shù)據(jù)庫(kù)對(duì)應(yīng)的jar包并導(dǎo)入

使用JDBC需要在工程中導(dǎo)入對(duì)應(yīng)的jar包。數(shù)據(jù)庫(kù)與JDBC包的對(duì)應(yīng)關(guān)系可以參考各種數(shù)據(jù)庫(kù)對(duì)應(yīng)的jar包、驅(qū)動(dòng)類名和URL格式。在Eclipse下的導(dǎo)入方法:

在工程的圖標(biāo)上右擊,選擇”P(pán)roperties”,在”Java Bulid Path”中選擇”Add External JARs…”,選擇下載并解壓后獲得的jar包。

       

如果對(duì)MySQL進(jìn)行操作,這時(shí)下面的import就不會(huì)報(bào)錯(cuò)了:

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基本操作

為了簡(jiǎn)單起見(jiàn),與數(shù)據(jù)庫(kù)相關(guān)的操作、命令、參數(shù)都被硬編碼了。有興趣的讀者可以對(duì)這些進(jìn)行探索,降低數(shù)據(jù)與操作的耦合性。

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

下面的所有方法和數(shù)據(jù)成員都在public class JDBCOperation內(nèi)部。

(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)連接的獲取

在操作前必須先獲取與數(shù)據(jù)庫(kù)的連接。

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,加載對(duì)應(yīng)驅(qū)動(dòng)
  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;
}

四、測(cè)試

在測(cè)試前,需要在系統(tǒng)中打開(kāi)對(duì)應(yīng)數(shù)據(jù)庫(kù)的服務(wù)。MySQL在Windows下的啟動(dòng)命令為net start mysql

測(cè)試代碼

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 
============================

五、代碼分析

在上述對(duì)數(shù)據(jù)庫(kù)進(jìn)行增刪改查的過(guò)程中,可以發(fā)現(xiàn)其共性部分,即通用的流程:

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

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

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

(4)先后關(guān)閉PreparedStatement對(duì)象和Connection對(duì)象。

可見(jiàn),使用JDBC時(shí),最常打交道的是Connection、PreparedStatement這兩個(gè)類,以及select中的ResultSet類。

Connection

java.sql

接口 Connection

所有超級(jí)接口:Wrapper

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

public interface Connectionextends Wrapper

與特定數(shù)據(jù)庫(kù)的連接(會(huì)話)。在連接上下文中執(zhí)行 SQL 語(yǔ)句并返回結(jié)果。

Connection 對(duì)象的數(shù)據(jù)庫(kù)能夠提供描述其表、所支持的 SQL 語(yǔ)法、存儲(chǔ)過(guò)程、此連接功能等等的信息。此信息是使用 getMetaData 方法獲得的。

PreparedStatemnt

java.sql

接口 PreparedStatement

所有超級(jí)接口:Statement, Wrapper所有已知子接口:CallableStatement

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

public interface PreparedStatementextends Statement

表示預(yù)編譯的 SQL 語(yǔ)句的對(duì)象。

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

常用方法

 boolean execute()

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

 ResultSet executeQuery()

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

 int executeUpdate()

在此 PreparedStatement 對(duì)象中執(zhí)行 SQL 語(yǔ)句,該語(yǔ)句必須是一個(gè) SQL 數(shù)據(jù)操作語(yǔ)言(Data Manipulation Language,DML)語(yǔ)句,比如 INSERT、UPDATE 或 DELETE 語(yǔ)句;或者是無(wú)返回內(nèi)容的 SQL 語(yǔ)句,比如 DDL 語(yǔ)句。

ResultSet

java.sql

接口 ResultSet

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

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

public interface ResultSetextends Wrapper

表示數(shù)據(jù)庫(kù)結(jié)果集的數(shù)據(jù)表,通常通過(guò)執(zhí)行查詢數(shù)據(jù)庫(kù)的語(yǔ)句生成。  

六、思考問(wèn)題

1.每次SQL操作都需要建立和關(guān)閉連接,這勢(shì)必會(huì)消耗大量的資源開(kāi)銷,如何避免?

分析:可以采用連接池,對(duì)連接進(jìn)行統(tǒng)一維護(hù),不必每次都建立和關(guān)閉。事實(shí)上這是很多對(duì)JDBC進(jìn)行封裝的工具所采用的。

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

分析:在執(zhí)行SQL語(yǔ)句時(shí),數(shù)據(jù)庫(kù)會(huì)嘗試進(jìn)行轉(zhuǎn)換。根據(jù)我的實(shí)驗(yàn),如果用內(nèi)容為純字母的String對(duì)象傳入tinyint的age屬性時(shí),會(huì)被轉(zhuǎn)化成0。具體轉(zhuǎn)化規(guī)則應(yīng)該和數(shù)據(jù)庫(kù)有關(guān)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

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

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

    下面小編就為大家?guī)?lái)一篇ArrayList刪除集合中某一屬性相同的元素方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • SpringBoot之返回json數(shù)據(jù)的實(shí)現(xiàn)方法

    SpringBoot之返回json數(shù)據(jù)的實(shí)現(xiàn)方法

    這篇文章主要介紹了SpringBoot之返回json數(shù)據(jù)的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • java版微信和支付寶退款接口

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

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

    Java女裝商城系統(tǒng)的實(shí)現(xiàn)流程

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

    解決springboot配置logback-spring.xml不起作用問(wèn)題

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

    Mybatis實(shí)現(xiàn)查詢相冊(cè)數(shù)據(jù)列表流程講解

    這篇文章主要介紹了Mybatis實(shí)現(xiàn)查詢相冊(cè)數(shù)據(jù)列表流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-12-12
  • 淺談關(guān)于Mybatis的mapper-locations配置問(wèn)題

    淺談關(guān)于Mybatis的mapper-locations配置問(wèn)題

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

    java的正則表達(dá)式你知道多少

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

    MyBatis-Plus框架整合詳細(xì)方法

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

    基于Springboot+Junit+Mockito做單元測(cè)試的示例

    本篇文章主要介紹了基于Springboot+Junit+Mockito做單元測(cè)試的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-02-02

最新評(píng)論