亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

首頁 Java Java基礎(chǔ) Java程式開發(fā)學(xué)習(xí)之JDBC與MySQL資料庫

Java程式開發(fā)學(xué)習(xí)之JDBC與MySQL資料庫

Feb 11, 2021 am 10:33 AM
java jdbc mysql資料庫

Java程式開發(fā)學(xué)習(xí)之JDBC與MySQL資料庫

相關(guān)學(xué)習(xí)推薦:java基礎(chǔ)

一、JDBC連接資料庫的操作

寫時可以封裝在一個類別裡面簡化程式碼。
(1)載入JDBC-MySQL資料庫驅(qū)動程式

try?{
????Class.forName("com.mysql.cj.jdbc.Driver");}catch?(Exception?e){?}

(2)連接資料庫

Connection?con?=?null;//聲明要連接數(shù)據(jù)庫的對象comString?uri?=?"jdbc:mysql://localhost:3306/數(shù)據(jù)庫名?useSSL=true?&characterEncoding=utf-8";	//連接地址String?user?=?"root";	//連接數(shù)據(jù)庫的用戶名String?password?=?"123456";	//連接數(shù)據(jù)庫的密碼try?{
????con?=?DriverManager.getConnection(uri,user,password);
	//連接代碼}catch(SQLException?e){?}

(3)編寫操作資料庫中資料的程式碼

#二、查詢操作

1,查詢操作的具體步驟
(1)向資料庫發(fā)送SQL語句:

Statement?sql;try{
????sql?=?con.createStatement();}catch?(SQLException?e){?}

首先聲明SQL語句對象,然後讓已建立的連線物件con呼叫方法createStatement()建立這個SQL語句物件。
(2)處理查詢結(jié)果
有了SQL語句物件後,這個物件可以呼叫對應(yīng)的方法來實現(xiàn)對資料庫中表格的各項操作,其中查詢結(jié)果存放在一個ResultSet類別聲明的物件中。即SQL查詢語句對資料庫的查詢操作講放回一個ResultSet對象,ResultSet由「列」(欄位)組織的資料行構(gòu)成。

rs?=?sql.executeQuery("select?*?from?表的名稱");//讀取表中的所有列,*為通配符rs?=?sql.executeQuery("select?行1字段名,行2字段名...?from?表的名稱");//讀取表中特定的列

ResultSet物件一次只能看到一行數(shù)據(jù),使用next()方法移到下一行。 ResultSet物件可以透過getXxx(int columnIndex)來取得列值和透過傳遞列名getXxx(String columnName)來取得列值。
(3)關(guān)閉連線

con.close();?//關(guān)閉con所連接的數(shù)據(jù)庫

注意:資料庫與連線物件緊密綁定,應(yīng)在使用完資料庫再進行關(guān)閉操作。

2,控制遊標
結(jié)果集的遊標的初始位置在結(jié)果集第一行的前面,結(jié)果集呼叫next()方法向下(後)移動遊標,移動成功回傳true,移動失敗回傳false。 如果要在結(jié)果集中移動並顯示若干筆記錄,必須傳回一個捲動的結(jié)果集。方法如下:

Statement?stmt?=?con.createStatement(int?type,int?concurrency);//獲得一個Statement對象,根據(jù)參數(shù)的值,stmt返回相應(yīng)類型的結(jié)果集:ResultSet?re?=?stmt.executeQuery(SQL語句);type的取值:決定滾動方式:
ResultSet.TYPE_FORWARD_ONLY?結(jié)果集的游標只能向下滾動
ResultSet.TYPE_SCROLL_INSENSITIVE?游標可以上下移動,數(shù)據(jù)庫變化時,結(jié)果集不變
ResultSet.TYPE_SCROLL_SENSITIVE?返回可滾動的結(jié)果集,數(shù)據(jù)變化時,結(jié)果集同步改變
Concurrency取值:決定是否可以用結(jié)果集更新數(shù)據(jù)庫
ResultSet.CONCUR_READ_ONLY?不能用結(jié)果集更新數(shù)據(jù)庫中的表
ResultSet.CONCUR_UPDATABLE?能用結(jié)果集更新數(shù)據(jù)庫中的表

滾動查詢常用的ResultSet的方法:public?boolean?previous()?將游標向上移動,當移動到結(jié)果集第一行之前時返回falsepublic?void?beforeFirst()?將游標移動到結(jié)果集的初始位置,第一行之前public?void?afterLast()?將游標移動到結(jié)果集的最后一行之后public?void?first()?將游標移動到第一行public?void?last()?將游標移動到最后一行public?boolean?isAfterLast()?判斷游標是否在最后一行之后public?boolean?isBeforeFirst()?判斷游標是否在第一行游標之前public?boolean?isFirst()?判斷游標是否指向第一行public?boolean?isLast()?判斷游標是否指向最后一行public?int?getRow()?得到當前游標所指向的行號,行號從1開始,如果結(jié)果集沒有行,返回0public?boolean?absolute(int?row)?將游標移動到參數(shù)row指定的行(參數(shù)取負數(shù)即倒數(shù))

(3)條件與排序查詢
where子語句:select 欄位from 顯示where 條件

#
(1)字段值與固定值比較
select?*?from?table?where?name='張三'(2)字段值在某個區(qū)間
select?*?from?table?where?number>5?and?number<10 and name!=&#39;李四&#39;(3)使用某些特殊的日期函數(shù)(Data:year-month-day)select * from table where year(表明日期的字段名)<1980 and month(表面日期的字段名)<=10select * from table where year(表明日期的字段名) between 2002 and 2021(4)使用某些特殊的時間函數(shù)(hour,minute,second)
select * from timelist where second(表明時間的字段名)=36(5)用操作符like進行模式匹配,使用%代替0個或多個字符,用一個下劃線_代替一個字符。
select * from table where name like&#39;%歐%&#39; //查詢name字段有“歐”字的記錄

order by語句:可結(jié)合where語句使用

select * from table order by height
select * from table where name like &#39;%王%&#39; order by name

三、更新、新增和刪除操作

Statement物件呼叫public int executeUpdate(String sqlStatement);透過參數(shù)指定的方式對資料庫表中的記錄的更新、新增和刪除操作。

(1)更新
update 表名 set 字段 = 新值 where <條件子句>(2)添加
insert?into?表?values?(對應(yīng)具體的記錄)(3)刪除
delete?from?表名?where?<條件子句>

四、使用預(yù)處理語句

Java提供了更有效率的資料庫操作機制,就是PreparedStatement對象,即預(yù)處理語句物件。將SQL語句處理為資料庫底層語句,再傳送給資料庫。
使用萬用字元:對SQL進行預(yù)處理時,可以用通配符? 來取代欄位的值,只要在預(yù)處理語句執(zhí)行之前再設(shè)定通配符所代表的具體值即可:

String?str?=?"select?*?from?表名?where?字段1?<???and?字段2?=??";PreparedStatement?sql?=?con.prepareStatement(str);sql.setXxx(int?parameterIndex,Type?x);//該方法設(shè)置?代表的值,parameterIndex代表第幾個?,x代表要替換的值。

#五、通用查詢

編寫通用查詢類,使用者可以將資料庫名稱、SQL語句傳遞給該類別的對象,那麼該對象就用一個二維數(shù)組返回查詢的記錄。
寫通用查詢類別需要知道資料庫表格列(欄位)的名字和數(shù)量。常用方法為用結(jié)果集ResultSet物件rs呼叫getMetaData()方法傳回一個ResultSetMetaData物件:

ResultSetMetaData?metaData?=?rs.getMetaData();

然後該物件metaData呼叫#getColumnCount()方法既可以傳回rs中列的數(shù)目,呼叫getColumnName(int i)就可以傳回結(jié)果集rs中第i列的名字。

六、交易

1,事務(wù)及處理
交易由一組SQL語句組成。所謂事務(wù)處理,是指應(yīng)用程式保證事務(wù)中的SQL語句要麼全部被執(zhí)行,要麼一個都不被執(zhí)行。事務(wù)處理是保證資料庫中資料完整性與一致性的重要機制。

2,JDBC事務(wù)處理
用setAutoCommit(boolean b)方法關(guān)閉自動模式:
即關(guān)閉SQL語句的即刻生效性,兩個相關(guān)聯(lián)的操作應(yīng)該在都執(zhí)行完畢後才改變資料庫中的資料。方法為在取得sql物件前讓連線物件呼叫此方法:

con.setAutoCommit(false);

用commit()方法處理交易:
關(guān)閉自動模式後,讓sql物件提交多條SQL(即相同交易)語句,這些語句不會立即生效,而是直到連線物件呼叫方法後全部生效:

con.commit();

用rollback()方法處理交易失?。?br> 即撤銷事務(wù)所作的動作。在con呼叫commit()方法進行事務(wù)處理時,只要有一個SQL語句沒有執(zhí)行成功,那麼該事務(wù)執(zhí)行失敗,拋出SQLException異常。這時必須讓con呼叫rollback()方法撤銷所有引起資料變化的操作:

con.rollback();

#相關(guān)免費學(xué)習(xí)推薦:##mysql影片教學(xué)

以上是Java程式開發(fā)學(xué)習(xí)之JDBC與MySQL資料庫的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
VSCODE設(shè)置。 JSON位置 VSCODE設(shè)置。 JSON位置 Aug 01, 2025 am 06:12 AM

settings.json文件位於用戶級或工作區(qū)級路徑,用於自定義VSCode設(shè)置。 1.用戶級路徑:Windows為C:\Users\\AppData\Roaming\Code\User\settings.json,macOS為/Users//Library/ApplicationSupport/Code/User/settings.json,Linux為/home//.config/Code/User/settings.json;2.工作區(qū)級路徑:項目根目錄下的.vscode/settings

如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

要正確處理JDBC事務(wù),必須先關(guān)閉自動提交模式,再執(zhí)行多個操作,最後根據(jù)結(jié)果提交或回滾;1.調(diào)用conn.setAutoCommit(false)以開始事務(wù);2.執(zhí)行多個SQL操作,如INSERT和UPDATE;3.若所有操作成功則調(diào)用conn.commit(),若發(fā)生異常則調(diào)用conn.rollback()確保數(shù)據(jù)一致性;同時應(yīng)使用try-with-resources管理資源,妥善處理異常並關(guān)閉連接,避免連接洩漏;此外建議使用連接池、設(shè)置保存點實現(xiàn)部分回滾,並保持事務(wù)盡可能短以提升性能。

在Java的掌握依賴注入春季和Guice 在Java的掌握依賴注入春季和Guice Aug 01, 2025 am 05:53 AM

依賴性(di)IsadesignpatternwhereObjectsReceivedenciesenciesExtern上,推廣looseSecouplingAndEaseerTestingThroughConstructor,setter,orfieldInjection.2.springfraMefringframeWorkSannotationsLikeLikeLike@component@component,@component,@service,@autowiredwithjava-service和@autowiredwithjava-ligatiredwithjava-lase-lightike

Python Itertools組合示例 Python Itertools組合示例 Jul 31, 2025 am 09:53 AM

itertools.combinations用於生成從可迭代對像中選取指定數(shù)量元素的所有不重複組合(順序無關(guān)),其用法包括:1.從列表中選2個元素組合,如('A','B')、('A','C')等,避免重複順序;2.對字符串取3個字符組合,如"abc"、"abd",適用於子序列生成;3.求兩數(shù)之和等於目標值的組合,如1 5=6,簡化雙重循環(huán)邏輯;組合與排列的區(qū)別在於順序是否重要,combinations視AB與BA為相同,而permutations視為不同;

故障排除常見的java`ofmemoryError`場景'' 故障排除常見的java`ofmemoryError`場景'' Jul 31, 2025 am 09:07 AM

java.lang.OutOfMemoryError:Javaheapspace表示堆內(nèi)存不足,需檢查大對象處理、內(nèi)存洩漏及堆設(shè)置,通過堆轉(zhuǎn)儲分析工具定位並優(yōu)化代碼;2.Metaspace錯誤因類元數(shù)據(jù)過多,常見於動態(tài)類生成或熱部署,應(yīng)限制MaxMetaspaceSize並優(yōu)化類加載;3.Unabletocreatenewnativethread因係統(tǒng)線程資源耗盡,需檢查線程數(shù)限制、使用線程池、調(diào)整棧大小;4.GCoverheadlimitexceeded指GC頻繁但回收少,應(yīng)分析GC日誌,優(yōu)化

Python Pytest夾具示例 Python Pytest夾具示例 Jul 31, 2025 am 09:35 AM

fixture是用於為測試提供預(yù)設(shè)環(huán)境或數(shù)據(jù)的函數(shù),1.使用@pytest.fixture裝飾器定義fixture;2.在測試函數(shù)中以參數(shù)形式註入fixture;3.yield之前執(zhí)行setup,之後執(zhí)行teardown;4.通過scope參數(shù)控製作用域,如function、module等;5.將共用fixture放在conftest.py中實現(xiàn)跨文件共享,從而提升測試的可維護性和復(fù)用性。

了解Java虛擬機(JVM)內(nèi)部 了解Java虛擬機(JVM)內(nèi)部 Aug 01, 2025 am 06:31 AM

TheJVMenablesJava’s"writeonce,runanywhere"capabilitybyexecutingbytecodethroughfourmaincomponents:1.TheClassLoaderSubsystemloads,links,andinitializes.classfilesusingbootstrap,extension,andapplicationclassloaders,ensuringsecureandlazyclassloa

如何使用Java的日曆? 如何使用Java的日曆? Aug 02, 2025 am 02:38 AM

使用java.time包中的類替代舊的Date和Calendar類;2.通過LocalDate、LocalDateTime和LocalTime獲取當前日期時間;3.使用of()方法創(chuàng)建特定日期時間;4.利用plus/minus方法不可變地增減時間;5.使用ZonedDateTime和ZoneId處理時區(qū);6.通過DateTimeFormatter格式化和解析日期字符串;7.必要時通過Instant與舊日期類型兼容;現(xiàn)代Java中日期處理應(yīng)優(yōu)先使用java.timeAPI,它提供了清晰、不可變且線

See all articles