JDBC 學習筆記+代碼整理

Tip

Idea自帶可視界面👉MySQL 圖形化界面-CSDN博客

Idea2022無add Framework support選項👉最新版IDEA:Add web Framework Support步驟/構建JavaWeb項目步驟_idea add framework support-CSDN博客

基本步驟

1.加載驅動包Driver

2.建立與數據庫的連接Connection DriverManager

3.發送SQL語句Statement

4.接收數據庫返回結果executeUpdate()/executeQuery()

5.解析結果ResultSet

6.關閉連接close()

加載驅動包Driver

package com.qf.JDBC;public class JdbcDriver {static {
//        1.加載驅動類try {
//            反射獲得驅動類DriverClass.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}
}

?創建和數據庫的連接

package com.qf.JDBC;import com.mysql.cj.jdbc.Driver;
import java.sql.*;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;public class JdbcDriver {private static String url="jdbc:mysql://localhost:3306/student?serverTimezone=UTC";
//    jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8   5
//    jdbc:mysql://localhost:3306/student?serverTimezone=UTC  8private static String username="root";//自己的用戶名private static String pass="123456";//自己的密碼static {
//        1.加載驅動類try {
//            反射獲得驅動類Driver
//            com.mysql.cj.jdbc.Driver 7Class.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}//    2.獲取連接public static Connection getConn() {Connection conn=null;try {conn = DriverManager.getConnection(url, username, pass);System.out.println("連接成功");} catch (SQLException e) {throw new RuntimeException(e);}return conn;}public static void main(String[] args) {getConn();}
}

發送Sql語句

例子:增加操作

package com.qf.JDBC;import com.mysql.cj.jdbc.Driver;
import java.sql.*;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.Stack;public class JdbcDriver {private static String url="jdbc:mysql://localhost:3306/student?serverTimezone=UTC";
//    jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8   5
//    jdbc:mysql://localhost:3306/student?serverTimezone=UTC  8private static String username="root";private static String pass="123456";static {
//        1.加載驅動類try {
//            反射獲得驅動類Driver
//            com.mysql.cj.jdbc.Driver 7Class.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}//    2.獲取連接public static Connection getConn() {Connection conn=null;try {conn = DriverManager.getConnection(url, username, pass);System.out.println("連接成功");} catch (SQLException e) {throw new RuntimeException(e);}return conn;}//    增加同學public static void addDept(){String sql="insert into student.table values('zt','男',20)";
//        獲得連接try {Statement st= getConn().createStatement();st.executeUpdate(sql);} catch (SQLException e) {throw new RuntimeException(e);}}public static void main(String[] args) {addDept();}
}

例子:查詢所有同學的信息

package com.qf.JDBC;import com.mysql.cj.jdbc.Driver;
import com.qf.JDBC.pojo.table;import javax.swing.*;
import java.sql.*;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Stack;public class JdbcDriver {private static String url="jdbc:mysql://localhost:3306/student?serverTimezone=UTC";
//    jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8   5
//    jdbc:mysql://localhost:3306/student?serverTimezone=UTC  8private static String username="root";private static String pass="123456";static {
//        1.加載驅動類try {
//            反射獲得驅動類Driver
//            com.mysql.cj.jdbc.Driver 7Class.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}//    2.獲取連接public static Connection getConn() {Connection conn=null;try {conn = DriverManager.getConnection(url, username, pass);System.out.println("連接成功");} catch (SQLException e) {throw new RuntimeException(e);}return conn;}//查詢所有學生信息public static ArrayList<table> queryAll(){ArrayList<table> list=new ArrayList<>();String sql="select * from student.table";
//        獲得連接Connection conn=getConn();Statement st=null;try {st=conn.createStatement();ResultSet r=st.executeQuery(sql);while (r.next()){table t=new table(r.getString(1),r.getString(2),r.getInt("age"));//分別是第一列 第二列 age列list.add(t);}} catch (SQLException e) {throw new RuntimeException(e);}finally {try {st.close();//先打開的流后關閉conn.close();} catch (SQLException e) {throw new RuntimeException(e);}}return list;}public static void main(String[] args) {ArrayList<table> arrayList=queryAll();for (table a:arrayList) {System.out.println(a);}}}
package com.qf.JDBC.pojo;import java.io.Serializable;public class table implements Serializable {//實體類 屬性與表一致private String name;private String gender;private int age;public table(String name, String gender, int age) {this.name = name;this.gender = gender;this.age = age;}public table() {}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}@Overridepublic String toString() {return "table{" +"name='" + name + '\'' +", gender='" + gender + '\'' +", age=" + age +'}';}
}

例子:修改和刪除

繼續用上面的table實體類

package com.qf.JDBC;import com.mysql.cj.jdbc.Driver;
import com.qf.JDBC.pojo.table;import javax.swing.*;
import java.sql.*;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Stack;public class JdbcDriver {private static String url="jdbc:mysql://localhost:3306/student?serverTimezone=UTC";
//    jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8   5
//    jdbc:mysql://localhost:3306/student?serverTimezone=UTC  8private static String username="root";private static String pass="123456";static {
//        1.加載驅動類try {
//            反射獲得驅動類Driver
//            com.mysql.cj.jdbc.Driver 7Class.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}//    2.獲取連接public static Connection getConn() {Connection conn=null;try {conn = DriverManager.getConnection(url, username, pass);System.out.println("連接成功");} catch (SQLException e) {throw new RuntimeException(e);}return conn;}//    修改部門public static void updateDept(){String sql="update student.table set age=21 where name='zt'";
//        獲得連接try {Statement st= getConn().createStatement();st.executeUpdate(sql);} catch (SQLException e) {throw new RuntimeException(e);}}//刪除public static void deleteDept(){String sql="delete from student.table where name='xx'";
//        獲得連接try {Statement st= getConn().createStatement();st.executeUpdate(sql);} catch (SQLException e) {throw new RuntimeException(e);}}public static void main(String[] args) {updateDept();deleteDept();}
}

JDBC實現分層處理

package com.xxxx.JDBC;//根包

common 公共包(所有模塊共用的類,數據庫連接類,分頁處理)
pojo(entiy)實體類的包(和表一一對應的類叫做實體類,Dept Emp)
test 測試包
dao 數據訪問對象(數據訪問層,對數據表增刪改查的代碼)
service 業務層(業務邏輯)

目錄

DBConn

package com.qf.JDBC.common;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;public class DBConn {private static String url="jdbc:mysql://localhost:3306/student?serverTimezone=UTC";//    jdbc:mysql://localhost:3306/student?useUnicode=true&characterEncoding=utf-8   5
//    jdbc:mysql://localhost:3306/student?serverTimezone=UTC  8private static String username="root";private static String pass="123456";static {
//        1.加載驅動類try {
//            反射獲得驅動類Driver
//            com.mysql.cj.jdbc.Driver 7Class.forName("com.mysql.cj.jdbc.Driver");} catch (ClassNotFoundException e) {throw new RuntimeException(e);}}//    2.獲取連接public static Connection getConn() {Connection conn=null;try {conn = DriverManager.getConnection(url, username, pass);System.out.println("連接成功");} catch (SQLException e) {throw new RuntimeException(e);}return conn;}
}

StuDao

package com.qf.JDBC.dao;import com.qf.JDBC.pojo.Student;public interface StuDao {void addStu(Student s);void updateStu(Student s);void delStu(Student s);}

StuDaoImpl

package com.qf.JDBC.dao;import com.qf.JDBC.common.DBConn;
import com.qf.JDBC.pojo.Student;import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.sql.Statement;public class StuDaoImpl extends DBConn implements StuDao{@Overridepublic void addStu(Student s) {String sql="insert into student.table(name,gender,age) values (?,?,?)";
//        獲得連接Connection conn =DBConn.getConn();PreparedStatement st=null;try {st= getConn().prepareStatement(sql);st.setString(1,s.getName());st.setString(2,s.getGender());st.setInt(3,s.getAge());//執行語句int r= st.executeUpdate();if(r>=1){System.out.println("新增成功");}else {System.out.println("新增失敗");}} catch (SQLException e) {throw new RuntimeException(e);}finally {try {st.close();} catch (SQLException e) {throw new RuntimeException(e);}try {conn.close();} catch (SQLException e) {throw new RuntimeException(e);}}}@Overridepublic void updateStu(Student s) {}@Overridepublic void delStu(Student s) {}
}

Student

package com.qf.JDBC.pojo;public class Student {private String name;private String gender;private int age;public Student(String name, String gender, int age) {this.name = name;this.gender = gender;this.age = age;}public Student() {}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}public int getAge() {return age;}public void setAge(int age) {this.age = age;}
}

StuService

package com.qf.JDBC.service;import com.qf.JDBC.dao.StuDao;
import com.qf.JDBC.dao.StuDaoImpl;
import com.qf.JDBC.pojo.Student;public class StuService {public static void main(String[] args) {StuDao stuDao=new StuDaoImpl();stuDao.addStu(new Student("張三","男",25));}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/40388.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/40388.shtml
英文地址,請注明出處:http://en.pswp.cn/web/40388.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

證券交易系統中服務器監控系統功能設計

1.背景介紹 此服務器監控系統的目的在于提高行情服務器的監管效率&#xff0c;因目前的的行情服務器&#xff0c;包括DM、DT、DS配置數量較多&#xff0c;巡回維護耗時較多&#xff0c;當行情服務器出現異常故障&#xff0c;或者因為網絡問題造成數據斷線等情況時&#xff0c;監…

芯科普| 矽光子是什麼?可以用在哪些領域?點擊查看!

隨著生成式人工智能的崛起&#xff0c;數據傳輸需求亦呈現爆發式增長。而在此背景下&#xff0c;臺積電在半導體展覽上披露的硅光子&#xff08;SiPh&#xff1a;Silicon Photonics&#xff09;技術進展&#xff0c;更是將硅光子推向了風口浪尖&#xff0c;成為了市場的寵兒。 …

IDEA導入依賴+Maven配置

Maven安裝及配置 安裝 安裝鏈接&#xff1a;https://archive.apache.org/dist/maven/maven-3/3.6.3/binaries/ 注&#xff1a;建議不要直接安裝最新版本&#xff0c;選用常用、穩定的版本安裝即可&#xff0c;比如&#xff1a;3.6.3 配置 1> 配置bash_profile文件 終端輸…

《知識點掃盲 · 監聽器 Listener》

&#x1f4e2; 大家好&#xff0c;我是 【戰神劉玉棟】&#xff0c;有10多年的研發經驗&#xff0c;致力于前后端技術棧的知識沉淀和傳播。 &#x1f497; &#x1f33b; CSDN入駐不久&#xff0c;希望大家多多支持&#xff0c;后續會繼續提升文章質量&#xff0c;絕不濫竽充數…

高效前端開發:解密pnpm的存儲與鏈接

什么是pnpm PNPM&#xff08;Performant NPM&#xff09;是一種快速且節省磁盤空間的包管理工具。相較于其他包管理器如NPM和Yarn&#xff0c;PNPM通過獨特的存儲機制和鏈接技術解決了許多常見的問題。以下是PNPM如何避免這些問題以及其關鍵技術的詳細介紹。 特性 PNPM Store…

批量注冊工具是什么

摘要&#xff1a;批量注冊工具作為自動化領域的一個分支&#xff0c;為用戶在多平臺賬號管理中提供了極大的便利。 關鍵詞 批量注冊&#xff0c;自動化&#xff0c;實戰代碼&#xff0c;設計原則&#xff0c;法律法規 1. 引言 批量注冊工具能夠在短時間內創建大量賬號&…

【MySQL備份】Percona XtraBackup總結篇

目錄 1.前言 2.問題總結 2.1.為什么在恢復備份前需要準備備份 2.1.1. 保證數據一致性 2.1.2. 完成崩潰恢復過程 2.1.3. 解決非鎖定備份的特殊需求 2.1.4. 支持增量和差異備份 2.1.5. 優化恢復性能 2.2.Percona XtraBackup的工作原理 3.注意事項 1.前言 在歷經了詳盡…

數據庫、創建表、修改表

一、數據庫 1、登陸數據庫 2、創建數據庫zoo 3、修改數據庫zoo字符集為gbk 4、選擇當前數據庫為zoo 5、查看創建數據庫zoo信息 6、刪除數據庫zoo 二、創建表 1、創建一個名稱為db_system的數據庫 2、在該數據庫下創建兩張表&#xff0c;具體要求如下 員工表 user…

圖像的對數變換

對數變換在圖像處理中通常有以下作用&#xff1a; 因為對數曲線在像素值較低的區域斜率較大&#xff0c;像素值較高的區域斜率比較低&#xff0c;所以圖像經過對數變換之后&#xff0c;在較暗的區域對比度將得到提升&#xff0c;因而能增強圖像暗部的細節。圖像的傅里葉頻譜其…

MySQL 結構的優化方案

主要是指三方面&#xff0c;即表結構、字段結構以及索引結構&#xff0c;這些結構如果不合理&#xff0c;在某些場景下也會影響數據庫的性能&#xff0c;因此優化時也可以從結構層面出發。一般在項目的庫表設計之初就要考慮&#xff0c;當性能瓶頸出現時再調整結構&#xff0c;…

Python函數語法詳解(與C++對比學習)【未完】

一、Python函數的形式 def function_name (參數, ...) -> return value_type:# 函數體return value# 看具體需求# 如果沒有return語句&#xff0c;函數執行完畢后也會返回結果# 只是結果為None。return None可以簡寫為return 1. Python的返回值 在Python3中&#xff0c;提…

利用Redis bitmap 實現簽到案例

數據庫實現 設計簽到功能對應的數據庫表 CREATE TABLE sign_record (id bigint NOT NULL AUTO_INCREMENT COMMENT 主鍵,user_id bigint NOT NULL COMMENT 用戶id,year year NOT NULL COMMENT 簽到年份,month tinyint NOT NULL COMMENT 簽到月份,date date NOT NULL COMMENT 簽…

EI檢索被認為是工程技術領域的權威數據庫

EI檢索被認為是工程技術領域的權威數據庫&#xff0c;能夠被EI檢索收錄的期刊和會議論文通常被認為具有一定的學術質量和影響力。然而&#xff0c;EI檢索與“高水平”不能完全畫等號&#xff0c;以下是一些需要考慮的因素&#xff1a; 1. 收錄標準&#xff1a;雖然EI檢索有嚴格…

在Linux操作系統中關于邏輯卷的案例

1.如何去創建一個邏輯卷 1.1先去創建物理卷 如上圖所示&#xff0c;physical volume 物理卷 被成功創建。 如上圖所示&#xff0c;可以使用pvscan來去查看當前Linux操作系統的物理卷/ 1.2使用創建好的物理卷去創建一個卷組。 如上圖所示&#xff0c;可以使用第一步創建的兩個…

【中項第三版】系統集成項目管理工程師 | 第 9 章 項目管理概論③ | 9.6 - 9.10

前言 第 9 章對應的內容選擇題和案例分析都會進行考查&#xff0c;這一章節理論性較強&#xff0c;學習要以教材為準。本章分值預計在4-5分。 目錄 9.6 項目管理過程組 9.7 項目管理原則 9.8 項目管理知識領域 9.9 價值交付系統 9.10 本章練習 9.6 項目管理過程組 項目…

千萬不能踏入的渠道管理五大誤區!【附策略】

一、引言 在當今激烈的市場競爭環境中&#xff0c;有效的渠道管理是企業獲得競爭優勢的關鍵。然而&#xff0c;在實踐過程中&#xff0c;不少企業因陷入管理誤區而影響了市場拓展和品牌建設。本文旨在揭示渠道管理中常見的五大誤區&#xff0c;并提供避免策略&#xff0c;幫助…

高級Redis之Stream的用法示例

不想自己搭建一個mq怎么辦&#xff1f;Redis的Stream 來幫你&#xff0c;Redis Stream 是 Redis 5.0 引入的一種新的數據結構&#xff0c;用于處理實時的、可持久化的、基于時間序列的數據流。它非常適合處理事件流、日志、消息隊列等場景。下面是一個使用 Redis Stream 的具體…

web基礎與HTTP協議(企業網站架構部署與優化)

補充&#xff1a;http服務首頁文件在/var/www/html下的&#xff0c;一定是index.html命名的文件。才會顯示出來。 如果該路徑下沒有相應的文件&#xff0c;會顯示/usr/share/httpd/noindex下的index.html文件。 如果/usr/share/httpd/noindex沒有index.html文件&#xff0c;會…

BSI 第七屆萬物互聯智慧高峰論壇:主題:擁抱AI時代,標準賦能組織實現可持續發展

BSI 第七屆萬物互聯智慧高峰論壇&#xff1a;主題&#xff1a;擁抱AI時代&#xff0c;標準賦能組織實現可持續發展 主要收到 BSI 溫女士的邀請參加的本次論壇。還是學到的很多 。 在科技日新月異的時代背景下&#xff0c;BSI 第七屆萬物互聯智慧高峰論壇于[時間&#xff1a;6…

Object 類中的公共方法詳解

Object 類中的公共方法詳解 1、clone() 方法2、equals(Object obj) 方法3、hashCode() 方法4、getClass() 方法5、wait() 方法6、notify() 和 notifyAll() 方法 &#x1f496;The Begin&#x1f496;點點關注&#xff0c;收藏不迷路&#x1f496; 在 Java 中&#xff0c;Object…