JDBC如何訪問MySQL數(shù)據(jù)庫,并增刪查改
導(dǎo)入驅(qū)動包,加載具體的驅(qū)動類
導(dǎo)包:
- 新建一個Java Project文件,在此文件夾下新建Folder文件命名lib(此文件夾下放一些導(dǎo)入的包)
- 將mysql-connector-java-xxxx.jar拖進來,右鍵Build Path→Add to Build Path;(這里我用的是mysql-connector-java-8.0.20.jar)
加載具體的驅(qū)動類:
Class.forName("com.mysql.cj.jdbc.Driver");
與數(shù)據(jù)庫建立連接connection
String url = "jdbc:mysql://localhost:3306/****?serverTimezone=UTC"; //****是你要訪問的數(shù)據(jù)庫是哪個,mysql版本5.0以上需要在后面加上serverTimezone=UTC //String url = "jdbc:mysql://localhost:3306/****?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC"; String username = "****"; //數(shù)據(jù)庫的用戶名 String password = "****";//數(shù)據(jù)庫的密碼 Connection con = DriverManager.getConnection(url, username, password);
發(fā)送sql語句,執(zhí)行sql語句(Statement)
增刪改操作:
Statement statement = connection.createStatement(); String sql = "insert into user values(1,'Jackage','857857')";//插入一條數(shù)據(jù) int executeUpdate = statement.executeUpdate(sql);//返回值表示改動了幾條數(shù)據(jù)
查詢操作:
String sql = "select name,password from user";<em>//查詢數(shù)據(jù)</em> ResultSet rs = statement.executeQuery(sql);
處理結(jié)果集(查詢)
處理增刪改的結(jié)果:
if (executeUpdate > 0) { System.out.println("操作成功?。?!"); } else { System.out.println("未發(fā)生改動?。。?!"); }
處理查詢的結(jié)果:
while (rs.next()) { String uname = rs.getString("name"); String upwd = rs.getString("password"); System.out.println(uname+ " " + upwd); }
以上是JDBC訪問數(shù)據(jù)庫的簡單步驟,中間我們還需要拋異常
除了Class.forName() 拋出ClassNotFoundException,其余方法全部拋SQLException
最后還需要關(guān)閉connection、statement、rs
關(guān)閉順序與打開時的順序相反,同時也要拋出異常
try { if(rs!=null)rs.close() if(stmt!=null) stmt.close(); if(connection!=null)connection.close(); } catch (SQLException e) { e.printStackTrace(); }
以上就是JDBC如何訪問MySQL數(shù)據(jù)庫的詳細(xì)內(nèi)容,更多關(guān)于JDBC訪問MySQL數(shù)據(jù)庫的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
mybatis查詢返回Map<String,Object>類型的講解
這篇文章主要介紹了mybatis查詢返回Map<String,Object>類型的講解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔代碼實例
這篇文章主要介紹了JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04詳解SpringBoot集成Redis來實現(xiàn)緩存技術(shù)方案
本篇文章主要介紹了詳解SpringBoot集成Redis來實現(xiàn)緩存技術(shù)方案,具有一定的參考價值,有興趣的可以了解一下2017-06-06SpringBoot中實現(xiàn)Redis緩存預(yù)熱
緩存預(yù)熱是一種在系統(tǒng)啟動后,但在實際使用前將數(shù)據(jù)加載到緩存中的技術(shù),本文主要來和大家一起探討如何在Spring Boot應(yīng)用程序中實現(xiàn)Redis緩存預(yù)熱,以確保系統(tǒng)在處理請求前就已經(jīng)處于最佳狀態(tài),感興趣的可以了解下2023-11-11如何解決報錯:java.net.BindException:無法指定被請求的地址問題
在Linux虛擬機上安裝并啟動Tomcat時遇到啟動失敗的問題,通過檢查端口及配置文件未發(fā)現(xiàn)異常,后發(fā)現(xiàn)/etc/hosts文件中缺少localhost的映射,添加后重啟Tomcat成功,Tomcat啟動時會檢查localhost的IP映射,缺失或錯誤都可能導(dǎo)致啟動失敗2024-10-10Java Vector實現(xiàn)班級信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java Vector實現(xiàn)班級信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02