利用jdbc對數據庫進行增刪改查

步驟/過程:

1,導入驅動包

2,加載驅動包

3,輸入信息,進行數據庫連接

4,創建? ? ? ? statement對象

5,執行sql語句

6,如果是查詢操作,利用ResultSet處理數據,再回收resultset對象,回收statement對象,回收connnection對象。如果是刪除,修改,添加,不需要ResultSet處理數據,直接回收statement對象,回收connnection對象。

在這個過程中用到的類

DriverManager驅動管理類注冊驅動程序,創建連接對象
Connection連接類

建立數據庫連接

Statementsql編輯器向數據庫發送要執行的sql語句
ResultSet查詢結果集執行查詢操作時,對返回結果進行處理
package com.qcby.test;import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;public class Test {//用戶信息和urlstatic final String url = "jdbc:mysql://localhost:3308/qcby";static final  String username="root";static final String password="root";public static void main(String[] ages) throws ClassNotFoundException, SQLException {String sql = "select * from student";search(sql);
//		String sql1= "INSERT INTO student(name,age,sex) VALUES(\"趙六\",24,\"女\")";
//		insert(sql1);}//利用jdbc進行查詢public static void search(String sql) throws ClassNotFoundException, SQLException {//1,加載驅動 報錯原因可能找不到//Class.forName("com.mysql.cj.jdbc.Dirver");Class.forName("com.mysql.jdbc.Driver");//2,驅動管理類調方法進行連接,創建管理類Connection connection= (Connection)DriverManager.getConnection(url,username,password);//3,創建執行sql對象Statement statement=(Statement)connection.createStatement();//4,執行sql語句executeQuery()應用在查詢出,獲得返回結果ResultSet resultSet=statement.executeQuery(sql);//5,resultSet處理數據while(resultSet.next()) {String id = resultSet.getString("id");String name = resultSet.getString("name");String sex = resultSet.getString("sex");String age = resultSet.getString("age");System.out.println("id:"+id+" 姓名:"+name+" 性別:"+sex+" 年齡:"+age);}//6,釋放資源if(resultSet!=null) {resultSet.close();}if(statement!=null) {statement.close();}if(connection!=null) {connection.close();}}//利用jdbc進行插入public static void insert(String sql) throws ClassNotFoundException, SQLException {//1,加載驅動 報錯原因可能找不到//Class.forName("com.mysql.cj.jdbc.Dirver");Class.forName("com.mysql.jdbc.Driver");//2,驅動管理類調方法進行連接,創建管理類Connection connection= (Connection)DriverManager.getConnection(url,username,password);//3,創建執行sql對象Statement statement=(Statement)connection.createStatement();//4,執行sql語句executeUpdate()應用插入statement.executeUpdate(sql);
//			//5,resultSet處理數據
//			while(resultSet.next()) {
//				String id = resultSet.getString("id");
//				String name = resultSet.getString("name");
//				String sex = resultSet.getString("sex");
//				String age = resultSet.getString("age");
//				System.out.println("id:"+id+" 姓名:"+name+" 性別:"+sex+" 年齡:"+age);
//			}//6,釋放資源if(statement!=null) {statement.close();}if(connection!=null) {connection.close();}}//利用jdbc進行修改public static void update(String sql) throws ClassNotFoundException, SQLException {//1,加載驅動 報錯原因可能找不到//Class.forName("com.mysql.cj.jdbc.Dirver");Class.forName("com.mysql.jdbc.Driver");//2,驅動管理類調方法進行連接,創建管理類Connection connection= (Connection)DriverManager.getConnection(url,username,password);//3,創建執行sql對象Statement statement=(Statement)connection.createStatement();//4,執行sql語句executeUpdate()應用插入statement.executeUpdate(sql);
//					//5,resultSet處理數據
//					while(resultSet.next()) {
//						String id = resultSet.getString("id");
//						String name = resultSet.getString("name");
//						String sex = resultSet.getString("sex");
//						String age = resultSet.getString("age");
//						System.out.println("id:"+id+" 姓名:"+name+" 性別:"+sex+" 年齡:"+age);
//					}//6,釋放資源if(statement!=null) {statement.close();}if(connection!=null) {connection.close();}}//利用jdbc進行刪除public static void delete(String sql) throws ClassNotFoundException, SQLException {//1,加載驅動 報錯原因可能找不到//Class.forName("com.mysql.cj.jdbc.Dirver");Class.forName("com.mysql.jdbc.Driver");//2,驅動管理類調方法進行連接,創建管理類Connection connection= (Connection)DriverManager.getConnection(url,username,password);//3,創建執行sql對象Statement statement=(Statement)connection.createStatement();//4,執行sql語句executeUpdate()應用插入statement.executeUpdate(sql);
//					//5,resultSet處理數據
//					while(resultSet.next()) {
//						String id = resultSet.getString("id");
//						String name = resultSet.getString("name");
//						String sex = resultSet.getString("sex");
//						String age = resultSet.getString("age");
//						System.out.println("id:"+id+" 姓名:"+name+" 性別:"+sex+" 年齡:"+age);
//					}//6,釋放資源if(statement!=null) {statement.close();}if(connection!=null) {connection.close();}}
}

?

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

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

相關文章

智能優化算法應用:基于鯨魚算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼

智能優化算法應用:基于鯨魚算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼 文章目錄 智能優化算法應用:基于鯨魚算法3D無線傳感器網絡(WSN)覆蓋優化 - 附代碼1.無線傳感網絡節點模型2.覆蓋數學模型及分析3.鯨魚算法4.實驗參數設定5.算法結果6.參考文獻7.MA…

Python-pdf工具自制(合并、拆分、刪除)

pdf工具,之前寫的合并工具有點麻煩,使用PyQt5庫重寫合并拆分和刪除指定頁面的程序 實現如圖: 代碼: import sysimport osfrom PyQt5.QtWidgets import QApplication, QMainWindow, QPushButton, QVBoxLayout, QWidget, QFileDia…

java 好碼

1【強制】不要在 foreach 循環里進行元素的 remove/add 操作。 remove 元素請使用 Iterator方式&#xff0c;如果并發操作&#xff0c;需要對 Iterator 對象加鎖。 正例&#xff1a; List<String> list new ArrayList<>(); list.add("1");list.add(…

unity 2d 入門 飛翔小鳥 Cinemachine 記錄分數(十二)

1、創建文本 右鍵->create->ui->leagcy->text 2、設置字體 3、設置默認值和數字 4、當切換分辨率&#xff0c;分數不見問題 拖拽這里調整 調整到如下圖 5、編寫得分腳本 using System.Collections; using System.Collections.Generic; using UnityEngine; …

Docker網絡架構介紹

本文主要介紹了Docker容器的單機網絡架構與集群網絡架構&#xff0c;輔以演示&#xff0c;并簡單介紹了網絡管理中的命令。 前文&#xff1a; Docker的安裝與簡單操作命令-CSDN博客 docker網絡原理介紹 與ovs類似&#xff0c;docker容器采用veth-pair linux bridge (虛擬交…

mysql語句練習

1、查詢"01"課程比"02"課程成績高的學生的信息及課程分數 SELECT student.*,s1.s_score,s2.s_score FROM student,score s1,score s2 WHERE student.s_ids1.s_id AND student.s_ids2.s_id AND s1.c_id01 AND s2.c_id02 AND s1.s_score>s2.s_score 2、…

0007Java程序設計-ssm基于微信小程序的在線考試系統

文章目錄 **摘要**目 錄系統實現開發環境 編程技術交流、源碼分享、模板分享、網課分享 企鵝&#x1f427;裙&#xff1a;776871563 摘要 網絡技術的快速發展給各行各業帶來了很大的突破&#xff0c;也給各行各業提供了一種新的管理技術&#xff0c;基于微信小程序的在線考試…

Linux下apisix離線安裝教程

Linux下apisix離線安裝教程 一、首先需要安裝etcd&#xff1a;二、通過rpm離線安裝apisix三、啟動apisix四、安裝apisix-dashboard1、安裝2、更改dashboard登錄賬號名和密碼3、運行 一、首先需要安裝etcd&#xff1a; 解壓縮etcd后執行以下命令&#xff1a; tar -xvf etcd-v3.…

C#注冊表技術及操作

目錄 一、注冊表基礎 1.Registry和RegistryKey類 &#xff08;1&#xff09;Registry類 &#xff08;2&#xff09;RegistryKey類 二、在C#中操作注冊表 1.讀取注冊表中的信息 &#xff08;1&#xff09;OpenSubKey()方法 &#xff08;2&#xff09;GetSubKeyNames()…

內外聯動——記建行江門鶴山支行營業部堵截一起新型騙局

建設銀行廣東省江門市分行&#xff08;以下簡稱“江門建行”&#xff09;認真貫徹落實黨中央、國務院決策部署&#xff0c;緊緊圍繞當地市委工作部署和上級行要求&#xff0c;扛牢國有大行責任&#xff0c;堅守金融工作的政治性、人民性&#xff0c;以深化新金融行動助力江門全…

javascript實現List列表數據結構

書籍推薦 有幸拜讀《數據結構與算法Javascript描述》這本書&#xff0c;先強烈安利一波&#xff01;非常感謝作者大大給我們前端領域帶來這本書。 全書從javascript的角度出發&#xff0c;簡單明了的分析了數據結構在javascript領域的實現過程與實際的應用案例&#xff0c;且…

postgres 登錄及常用命令

登陸 輸入以下命令&#xff0c;嘗試登錄psql: psql -U postgres 報告以下錯誤&#xff1a; psql: error: connection to server on socket "/var/run/postgresql/.s.PGSQL.5432" failed: FATAL: Peer authentication failed for user "postgres" 換成下面…

Initializing libiomp5md.dll, but found libiomp5md.dll already initialized.

報錯&#xff1a; OMP: Error #15: Initializing libiomp5md.dll, but found libiomp5md.dll already initialized. OMP: Hint This means that multiple copies of the OpenMP runtime have been linked into the program. That is dangerous, since it can degrade performan…

差異計算基礎知識 - 了解期末業務操作、WIP 和差異

原文地址&#xff1a;Basics of variance calculation-Understanding Period End activities, WIP and Variances | SAP Blogs 大家好&#xff0c; 這是我在成本核算方面的第六份文件&#xff0c;旨在解釋期末的差異計算和相關活動。 我將引導您完成期末活動和差異計算。在本文…

MySQL char 尾隨空格丟失與右側空格填充

今天看《高性能MySQL(第四版)》,講char,varchar時說“當存儲CHAR值時&#xff0c;MySQL刪除所有尾隨空格。如果需要進行比較&#xff0c;值會用空格填充。”感覺這兩句話有沖突啊&#xff0c;便研究了下。 對于具體的問題&#xff0c;當然官方文檔是最好的&#xff0c;The CHAR…

【性能測試】Jmeter 配置元件(一):計數器

Jmeter 配置元件&#xff08;一&#xff09;&#xff1a;計數器 在 Jmeter 中&#xff0c;通過函數 ${__counter(,)} 可以實現每次加 1 1 1 的計數效果。但如果步長不為 1 1 1&#xff0c;則要利用到我們的計數器。 函數作用${__counter(,)}計數器&#xff0c;每次加 1${__d…

vue父子組件傳值

父組件向子組件傳值 1.在父組件中調用子組件時&#xff0c;定義要傳遞的參數 //使用子組件&#xff0c;并傳遞value作為prop<childComponent :childValue"parentValue"></childComponent>// 父組件的data中定義傳遞的參數data() {return {parentValue: &…

論文導讀|10月MSOM文章精選:智慧醫療

編者按 在“10月MSOM文章精選&#xff1a;智慧醫療”中&#xff0c;我們有主題、有針對性地選擇了MSOM期刊雜志中一些有關智慧醫療領域的有趣文章&#xff0c;不但對文章的內容進行了概括與點評&#xff0c;而且也對文章的結構進行了梳理&#xff0c;旨在激發廣大讀者的閱讀興趣…

c++--面向對象特性

1.面向對象指的是繼承&#xff0c;封裝&#xff0c;多態。 繼承主要關注類的構造&#xff0c;賦值&#xff0c;析構。 以下對多態&#xff0c;封裝進行補充說明。 2、多態 2.1.定義 a.賦值 派生類的指針&#xff0c;可以賦值給基類的指針。 派送類的對象&#xff0c;可以賦值給…

教師需要什么技能?

作為一名老師&#xff0c;需要掌握許多技能&#xff0c;以便能夠成功地教育和指導學生。以下是一些關鍵技能&#xff1a; 1.教學技能&#xff1a;老師需要有深入的學科知識和教學經驗&#xff0c;以便能夠有效地傳授知識。教師應該了解如何設計和執行教學計劃&#xff0c;制定課…