国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java面試題 java高頻率基礎(chǔ)面試題-(五)

java高頻率基礎(chǔ)面試題-(五)

Sep 03, 2020 pm 04:24 PM
java 面試題

java高頻率基礎(chǔ)面試題-(五)

1、JDBC存取資料庫的基本步驟是什麼?

(更多面試題推薦:java面試題目及答案

載入驅(qū)動(dòng)程式

透過DriverManager物件取得連線物件Connection

#透過連線物件取得會(huì)話

透過會(huì)話進(jìn)行資料的增刪改查,封裝物件

#關(guān)閉資源

2、說preparedStatement和Statement的差異

#效率:預(yù)編譯會(huì)話比普通會(huì)話對(duì)象,資料庫系統(tǒng)不會(huì)對(duì)相同的sql語句不會(huì)再次編譯

安全性:可以有效的避免sql注入攻擊! sql注入攻擊就是從客戶端輸入一些非法的特殊字符,而使伺服器端在構(gòu)造sql語句的時(shí)候仍然能夠正確構(gòu)造,從而收集程式和伺服器的資訊和資料。

例如:

“select * from t_user where userName = ‘” + userName + “ ’ and password =’” + password + “’”

如果使用者名稱和密碼輸入的是'1' or '1'='1' ;? 則生產(chǎn)的sql語句是:

“select * from t_user where userName = ‘1’ or ‘1’ =’1’  and password =’1’  or ‘1’=’1’

這個(gè)語句中的where 部分沒有起到對(duì)資料篩選的作用。

3、說說事務(wù)的概念,在JDBC程式設(shè)計(jì)中處理交易的步驟

交易是作為單一邏輯工作單元執(zhí)行的一系列操作。

一個(gè)邏輯工作單元必須有四個(gè)屬性,稱為原子性、一致性、隔離性和持久性(ACID) 屬性,只有這樣才能成為一個(gè)是交易

事務(wù)處理步驟:

conn.setAutoComit(false);設(shè)定提交方式為手動(dòng)提交

conn.commit()提交交易

出現(xiàn)異常,回滾conn.rollback();

4、資料庫連線池的原理。為什麼要使用連線池。

資料庫連線是一件費(fèi)時(shí)的操作,連線池可以讓多個(gè)操作共用一個(gè)連線。

資料庫連線池的基本概念就是為資料庫連線建立一個(gè)「緩衝池」。預(yù)先在緩衝池中放入一定數(shù)量的連接,當(dāng)需要建立資料庫連接時(shí),只需從「緩衝池」中取出一個(gè),使用完畢之後再放回去。我們可以透過設(shè)定連線池最大連線數(shù)來防止系統(tǒng)無盡的與資料庫連線。更重要的是我們可以透過連接池的管理機(jī)制來監(jiān)視資料庫的連接的數(shù)量、使用情況,為系統(tǒng)開發(fā),測(cè)試及效能調(diào)整提供依據(jù)。

使用連接池是為了提高對(duì)資料庫連接資源的管理

(相關(guān)推薦:java入門教學(xué)

5、JDBC的髒讀是什麼?哪種資料庫隔離等級(jí)能防止髒讀?

當(dāng)我們使用交易時(shí),有可能會(huì)出現(xiàn)這樣的情況,有一行資料剛更新,同時(shí)另一個(gè)查詢讀到了這個(gè)剛更新的值。這樣就導(dǎo)致了髒讀,因?yàn)楦碌馁Y料還沒有進(jìn)行持久化,更新這行資料的業(yè)務(wù)可能會(huì)進(jìn)行回滾,這樣這個(gè)資料就是無效的。資料庫的TRANSACTIONREADCOMMITTED,TRANSACTIONREPEATABLEREAD,和TRANSACTION_SERIALIZABLE隔離等級(jí)可以防止髒讀。

6、什麼是幻讀,哪一種隔離等級(jí)可以防止幻讀?

幻讀是指一個(gè)交易多次執(zhí)行一條查詢回傳的卻是不同的值。假設(shè)一個(gè)事務(wù)正根據(jù)某個(gè)條件進(jìn)行資料查詢,然後另一個(gè)事務(wù)插入了一行滿足這個(gè)查詢條件的資料。之後這個(gè)事務(wù)又執(zhí)行了這條查詢,傳回的結(jié)果集中會(huì)包含剛插入的那條新資料。這行新資料稱為幻行,而這種現(xiàn)象就叫做幻讀。

只有TRANSACTION_SERIALIZABLE隔離等級(jí)才能防止產(chǎn)生幻讀。

7、JDBC的DriverManager是用來做什麼的?

JDBC的DriverManager是一個(gè)工廠類,我們透過它來建立資料庫連線。當(dāng)JDBC的Driver類別被載入進(jìn)來時(shí),它會(huì)自己註冊(cè)到DriverManager類別裡面

然後我們會(huì)把資料庫設(shè)定資訊傳遞到DriverManager.getConnection()方法,DriverManager會(huì)使用註冊(cè)到它裡面的驅(qū)動(dòng)程式來取得資料庫連接,並傳回給呼叫的程式。

8、execute,executeQuery,executeUpdate的差別是什麼?

Statement的execute(String query)方法用來執(zhí)行任意的SQL查詢,如果查詢的結(jié)果是一個(gè)ResultSet,這個(gè)方法就回傳true。如果結(jié)果不是ResultSet,例如insert或update查詢,它就會(huì)回傳false。我們可以透過它的getResultSet方法來取得ResultSet,或是透過getUpdateCount()方法來取得更新的記錄條數(shù)。?

Statement的executeQuery(String query)介面用來執(zhí)行select查詢,並且回傳ResultSet。即使查詢不到記錄回傳的ResultSet也不會(huì)為null。我們通常使用executeQuery來執(zhí)行查詢語句,這樣的話如果傳進(jìn)來的是insert或update語句的話,它會(huì)拋出錯(cuò)誤訊息為 “executeQuery method can not be used for update”的java.util.SQLException。?

Statement的executeUpdate(String query)方法用來執(zhí)行insert或者update/delete(DML)語句,或者 什么也不返回,對(duì)于DDL語句,返回值是int類型,如果是DML語句的話,它就是更新的條數(shù),如果是DDL的話,就返回0。

只有當(dāng)你不確定是什么語句的時(shí)候才應(yīng)該使用execute()方法,否則應(yīng)該使用executeQuery或者executeUpdate方法。

9、SQL查詢出來的結(jié)果分頁展示一般怎么做?

Oracle:

select * from
(select *,rownum as tempid from student )  t
where t.tempid between ” + pageSize*(pageNumber-1) + ” and ” + pageSize*pageNumber

MySQL:

select * from students limit ” + pageSize*(pageNumber-1) + “,” + pageSize;

sql server:

select top ” + pageSize + ” * from students where id not in +
(select top ” + pageSize * (pageNumber-1) +  id from students order by id) +  
“order by id;

(視頻教程推薦:java課程

10、JDBC的ResultSet是什么?

在查詢數(shù)據(jù)庫后會(huì)返回一個(gè)ResultSet,它就像是查詢結(jié)果集的一張數(shù)據(jù)表。

ResultSet對(duì)象維護(hù)了一個(gè)游標(biāo),指向當(dāng)前的數(shù)據(jù)行。開始的時(shí)候這個(gè)游標(biāo)指向的是第一行。如果調(diào)用了ResultSet的next()方法游標(biāo)會(huì)下移一行,如果沒有更多的數(shù)據(jù)了,next()方法會(huì)返回false??梢栽趂or循環(huán)中用它來遍歷數(shù)據(jù)集。

默認(rèn)的ResultSet是不能更新的,游標(biāo)也只能往下移。也就是說你只能從第一行到最后一行遍歷一遍。不過也可以創(chuàng)建可以回滾或者可更新的ResultSet。

當(dāng)生成ResultSet的Statement對(duì)象要關(guān)閉或者重新執(zhí)行或是獲取下一個(gè)ResultSet的時(shí)候,ResultSet對(duì)象也會(huì)自動(dòng)關(guān)閉。
可以通過ResultSet的getter方法,傳入列名或者從1開始的序號(hào)來獲取列數(shù)據(jù)。

以上是java高頻率基礎(chǔ)面試題-(五)的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

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

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

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

SublimeText3 Mac版

SublimeText3 Mac版

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

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時(shí)獲取鍵和值,適用於大多數(shù)場(chǎng)景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結(jié)構(gòu)。 entrySet返回包含所有鍵值對(duì)的Set集合,每次循環(huán)獲取Map.Entry對(duì)象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調(diào)用keySet()或values(),也可在遍歷鍵時(shí)通過map.get(key)獲取值;Java8中可通過Lambda表達(dá)式使用forEach((key,value)-&gt

Java可選示例 Java可選示例 Jul 12, 2025 am 02:55 AM

Optional能清晰表達(dá)意圖並減少null判斷的代碼噪音。 1.Optional.ofNullable是處理可能為null對(duì)象的常用方式,如從map中取值時(shí)可結(jié)合orElse提供默認(rèn)值,邏輯更清晰簡潔;2.通過鍊式調(diào)用map實(shí)現(xiàn)嵌套取值,安全地避免NPE,任一環(huán)節(jié)為null則自動(dòng)終止並返回默認(rèn)值;3.filter可用於條件篩選,滿足條件才繼續(xù)執(zhí)行後續(xù)操作,否則直接跳到o??rElse,適合輕量級(jí)業(yè)務(wù)判斷;4.不建議過度使用Optional,如基本類型或簡單邏輯中其反而增加複雜度,部分場(chǎng)景直接返回nu

如何修復(fù)java.io.notserializable Exception? 如何修復(fù)java.io.notserializable Exception? Jul 12, 2025 am 03:07 AM

遇到j(luò)ava.io.NotSerializableException的核心解決方法是確保所有需序列化的類實(shí)現(xiàn)Serializable接口,並檢查嵌套對(duì)象的序列化支持。 1.給主類添加implementsSerializable;2.確保類中自定義字段對(duì)應(yīng)的類也實(shí)現(xiàn)Serializable;3.用transient標(biāo)記不需要序列化的字段;4.檢查集合或嵌套對(duì)像中的非序列化類型;5.查看異常信息定位具體哪個(gè)類未實(shí)現(xiàn)接口;6.對(duì)無法修改的類考慮替換設(shè)計(jì),如保存關(guān)鍵數(shù)據(jù)或使用可序列化的中間結(jié)構(gòu);7.考慮改

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用於類內(nèi)部定義默認(rèn)排序規(guī)則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類自身實(shí)現(xiàn)的接口,通過重寫compareTo()方法定義自然順序,適用於類有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數(shù)式接口,通過compare()方法實(shí)現(xiàn),適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在於Comparable只能定義一種排序邏輯且需修改類本身,而Compar

如何在Java解析JSON? 如何在Java解析JSON? Jul 11, 2025 am 02:18 AM

解析JSON在Java中的常見方式有三種:使用Jackson、Gson或org.json。 1.Jackson適合大多數(shù)項(xiàng)目,性能好且功能全面,支持對(duì)象與JSON字符串之間的轉(zhuǎn)換及註解映射;2.Gson更適合Android項(xiàng)目或輕量級(jí)需求,使用簡單但處理複雜結(jié)構(gòu)和高性能場(chǎng)景略遜;3.org.json適用於簡單任務(wù)或小腳本,不推薦用於大型項(xiàng)目,因其靈活性和類型安全不足。選擇應(yīng)根據(jù)實(shí)際需求決定。

Java方法參考解釋了 Java方法參考解釋了 Jul 12, 2025 am 02:59 AM

方法引用是Java中一種簡化Lambda表達(dá)式的寫法,使代碼更簡潔。它不是新語法,而是Java8引入的Lambda表達(dá)式的一種快捷方式,適用於函數(shù)式接口的上下文。其核心在於將已有方法直接作為函數(shù)式接口的實(shí)現(xiàn)來使用。例如System.out::println等價(jià)於s->System.out.println(s)。方法引用主要有四種形式:1.靜態(tài)方法引用(ClassName::staticMethodName);2.實(shí)例方法引用(綁定到特定對(duì)象,instance::methodName);3.

如何處理Java中的字符編碼問題? 如何處理Java中的字符編碼問題? Jul 13, 2025 am 02:46 AM

處理Java中的字符編碼問題,關(guān)鍵是在每一步都明確指定使用的編碼。 1.讀寫文本時(shí)始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴系統(tǒng)默認(rèn)編碼。 2.在網(wǎng)絡(luò)邊界處理字符串時(shí)確保兩端一致,設(shè)置正確的Content-Type頭並用庫顯式指定編碼。 3.謹(jǐn)慎使用String.getBytes()和newString(byte[]),應(yīng)始終手動(dòng)指定StandardCharsets.UTF_8以避免平臺(tái)差異導(dǎo)致的數(shù)據(jù)損壞。總之,通過在每個(gè)階段

新電子郵件的Outlook快捷方式 新電子郵件的Outlook快捷方式 Jul 11, 2025 am 03:25 AM

在Outlook中快速新建郵件的方法如下:1.桌面版使用快捷鍵Ctrl Shift M,可直接彈出新郵件窗口;2.網(wǎng)頁版可通過創(chuàng)建包含JavaScript的書籤(如javascript:document.querySelector("divrole='button'").click())實(shí)現(xiàn)一鍵新建郵件;3.使用瀏覽器插件(如Vimium、CrxMouseGestures)自定義快捷鍵觸發(fā)“新建郵件”按鈕;4.Windows用戶還可通過右鍵任務(wù)欄Outlook圖標(biāo)選擇“新建電

See all articles