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

首頁(yè) Java Java面試題 javaweb面試題目(2)

javaweb面試題目(2)

Dec 06, 2019 pm 03:02 PM
java

javaweb面試題目(2)

JDBC訪(fǎng)問(wèn)數(shù)據(jù)庫(kù)的基本步驟是什么?? ? ? ? ? ? ? ? ?(推薦學(xué)習(xí):java面試題目

1,加載驅(qū)動(dòng)

2,通過(guò)DriverManager對(duì)象獲取連接對(duì)象Connection

3,通過(guò)連接對(duì)象獲取會(huì)話(huà)

4,通過(guò)會(huì)話(huà)進(jìn)行數(shù)據(jù)的增刪改查,封裝對(duì)象

5,關(guān)閉資源

說(shuō)說(shuō)preparedStatement和Statement的區(qū)別

1,效率:預(yù)編譯會(huì)話(huà)比普通會(huì)話(huà)對(duì)象,數(shù)據(jù)庫(kù)系統(tǒng)不會(huì)對(duì)相同的sql語(yǔ)句不會(huì)再次編譯

2,安全性:可以有效的避免sql注入攻擊!sql注入攻擊就是從客戶(hù)端輸入一些非法的特殊字符,而使服務(wù)器端在構(gòu)造sql語(yǔ)句的時(shí)候仍然能夠正確構(gòu)造,從而收集程序和服務(wù)器的信息和數(shù)據(jù)。

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

如果用戶(hù)名和密碼輸入的是’1’ or ‘1’=’1’ ;? 則生產(chǎn)的sql語(yǔ)句是:

“select * from t_user where userName = ‘1’ or ‘1’ =’1’? and password =’1’? or ‘1’=’1’? 這個(gè)語(yǔ)句中的where 部分沒(méi)有起到對(duì)數(shù)據(jù)篩選的作用。

說(shuō)說(shuō)事務(wù)的概念,在JDBC編程中處理事務(wù)的步驟。

1 事務(wù)是作為單個(gè)邏輯工作單元執(zhí)行的一系列操作。

2,一個(gè)邏輯工作單元必須有四個(gè)屬性,稱(chēng)為原子性、一致性、隔離性和持久性 (ACID) 屬性,只有這樣才能成為一個(gè)事務(wù)

事務(wù)處理步驟:

3,conn.setAutoComit(false);設(shè)置提交方式為手工提交

4,conn.commit()提交事務(wù)

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

數(shù)據(jù)庫(kù)連接池的原理,為什么要使用連接池?

1,數(shù)據(jù)庫(kù)連接是一件費(fèi)時(shí)的操作,連接池可以使多個(gè)操作共享一個(gè)連接。

2,數(shù)據(jù)庫(kù)連接池的基本思想就是為數(shù)據(jù)庫(kù)連接建立一個(gè)“緩沖池”。預(yù)先在緩沖池中放入一定數(shù)量的連接,當(dāng)需要建立數(shù)據(jù)庫(kù)連接時(shí),只需從“緩沖池”中取出一個(gè),使用完畢之后再放回去。

我們可以通過(guò)設(shè)定連接池最大連接數(shù)來(lái)防止系統(tǒng)無(wú)盡的與數(shù)據(jù)庫(kù)連接。更為重要的是我們可以通過(guò)連接池的管理機(jī)制監(jiān)視數(shù)據(jù)庫(kù)的連接的數(shù)量、使用情況,為系統(tǒng)開(kāi)發(fā),測(cè)試及性能調(diào)整提供依據(jù)。

3,使用連接池是為了提高對(duì)數(shù)據(jù)庫(kù)連接資源的管理

JDBC的臟讀是什么?哪種數(shù)據(jù)庫(kù)隔離級(jí)別能防止臟讀?

當(dāng)我們使用事務(wù)時(shí),有可能會(huì)出現(xiàn)這樣的情況,有一行數(shù)據(jù)剛更新,與此同時(shí)另一個(gè)查詢(xún)讀到了這個(gè)剛更新的值。這樣就導(dǎo)致了臟讀,因?yàn)楦碌臄?shù)據(jù)還沒(méi)有進(jìn)行持久化,更新這行數(shù)據(jù)的業(yè)務(wù)可能會(huì)進(jìn)行回滾,這樣這個(gè)數(shù)據(jù)就是無(wú)效的。

數(shù)據(jù)庫(kù)的TRANSACTIONREADCOMMITTED,TRANSACTIONREPEATABLEREAD,和TRANSACTION_SERIALIZABLE隔離級(jí)別可以防止臟讀。

什么是幻讀,哪種隔離級(jí)別可以防止幻讀?

幻讀是指一個(gè)事務(wù)多次執(zhí)行一條查詢(xún)返回的卻是不同的值。假設(shè)一個(gè)事務(wù)正根據(jù)某個(gè)條件進(jìn)行數(shù)據(jù)查詢(xún),然后另一個(gè)事務(wù)插入了一行滿(mǎn)足這個(gè)查詢(xún)條件的數(shù)據(jù)。

之后這個(gè)事務(wù)再次執(zhí)行了這條查詢(xún),返回的結(jié)果集中會(huì)包含剛插入的那條新數(shù)據(jù)。這行新數(shù)據(jù)被稱(chēng)為幻行,而這種現(xiàn)象就叫做幻讀。

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

JDBC的DriverManager是用來(lái)做什么的?

JDBC的DriverManager是一個(gè)工廠(chǎng)類(lèi),我們通過(guò)它來(lái)創(chuàng)建數(shù)據(jù)庫(kù)連接。當(dāng)JDBC的Driver類(lèi)被加載進(jìn)來(lái)時(shí),它會(huì)自己注冊(cè)到DriverManager類(lèi)里面

然后我們會(huì)把數(shù)據(jù)庫(kù)配置信息傳成DriverManager.getConnection()方法,DriverManager會(huì)使用注冊(cè)到它里面的驅(qū)動(dòng)來(lái)獲取數(shù)據(jù)庫(kù)連接,并返回給調(diào)用的程序。

execute,executeQuery,executeUpdate的區(qū)別是什么?

1,Statement的execute(String query)方法用來(lái)執(zhí)行任意的SQL查詢(xún),如果查詢(xún)的結(jié)果是一個(gè)ResultSet,這個(gè)方法就返回true。如果結(jié)果不是ResultSet,比如insert或者update查詢(xún),它就會(huì)返回false。

我們可以通過(guò)它的getResultSet方法來(lái)獲取ResultSet,或者通過(guò)getUpdateCount()方法來(lái)獲取更新的記錄條數(shù)。?

2,Statement的executeQuery(String query)接口用來(lái)執(zhí)行select查詢(xún),并且返回ResultSet。即使查詢(xún)不到記錄返回的ResultSet也不會(huì)為null。

我們通常使用executeQuery來(lái)執(zhí)行查詢(xún)語(yǔ)句,這樣的話(huà)如果傳進(jìn)來(lái)的是insert或者update語(yǔ)句的話(huà),它會(huì)拋出錯(cuò)誤信息為 “executeQuery method can not be used for update”的java.util.SQLException。 ,

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

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

SQL查詢(xún)出來(lái)的結(jié)果分頁(yè)展示一般怎么做?

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;

JDBC的ResultSet是什么?

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

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

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

當(dāng)生成ResultSet的Statement對(duì)象要關(guān)閉或者重新執(zhí)行或是獲取下一個(gè)ResultSet的時(shí)候,ResultSet對(duì)象也會(huì)自動(dòng)關(guān)閉。

可以通過(guò)ResultSet的getter方法,傳入列名或者從1開(kāi)始的序號(hào)來(lái)獲取列數(shù)據(jù)。

以上是javaweb面試題目(2)的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系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

用于從照片中去除衣服的在線(xiàn)人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

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集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話(huà)題

Laravel 教程
1601
29
PHP教程
1502
276
如何使用JDBC處理Java的交易? 如何使用JDBC處理Java的交易? Aug 02, 2025 pm 12:29 PM

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

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

比較Java框架:Spring Boot vs Quarkus vs Micronaut 比較Java框架:Spring Boot vs Quarkus vs Micronaut Aug 04, 2025 pm 12:48 PM

前形式攝取,quarkusandmicronautleaddueTocile timeProcessingandGraalvSupport,withquarkusoftenpernperforminglightbetterine nosserless notelless centarios.2。

了解網(wǎng)絡(luò)端口和防火墻 了解網(wǎng)絡(luò)端口和防火墻 Aug 01, 2025 am 06:40 AM

NetworkPortSandFireWallsworkTogetHertoEnableCommunication whereSeringSecurity.1.NetWorkPortSareVirtualendPointSnumbered0-655 35,with-Well-with-Newonportslike80(HTTP),443(https),22(SSH)和25(smtp)sindiessingspefificservices.2.portsoperateervertcp(可靠,c

垃圾收集如何在Java工作? 垃圾收集如何在Java工作? Aug 02, 2025 pm 01:55 PM

Java的垃圾回收(GC)是自動(dòng)管理內(nèi)存的機(jī)制,通過(guò)回收不可達(dá)對(duì)象釋放堆內(nèi)存,減少內(nèi)存泄漏風(fēng)險(xiǎn)。1.GC從根對(duì)象(如棧變量、活動(dòng)線(xiàn)程、靜態(tài)字段等)出發(fā)判斷對(duì)象可達(dá)性,無(wú)法到達(dá)的對(duì)象被標(biāo)記為垃圾。2.基于標(biāo)記-清除算法,標(biāo)記所有可達(dá)對(duì)象,清除未標(biāo)記對(duì)象。3.采用分代收集策略:新生代(Eden、S0、S1)頻繁執(zhí)行MinorGC;老年代執(zhí)行較少但耗時(shí)較長(zhǎng)的MajorGC;Metaspace存儲(chǔ)類(lèi)元數(shù)據(jù)。4.JVM提供多種GC器:SerialGC適用于小型應(yīng)用;ParallelGC提升吞吐量;CMS降

比較Java構(gòu)建工具:Maven vs. Gradle 比較Java構(gòu)建工具:Maven vs. Gradle Aug 03, 2025 pm 01:36 PM

Gradleisthebetterchoiceformostnewprojectsduetoitssuperiorflexibility,performance,andmoderntoolingsupport.1.Gradle’sGroovy/KotlinDSLismoreconciseandexpressivethanMaven’sverboseXML.2.GradleoutperformsMaveninbuildspeedwithincrementalcompilation,buildcac

以身作則,解釋說(shuō)明 以身作則,解釋說(shuō)明 Aug 02, 2025 am 06:26 AM

defer用于在函數(shù)返回前執(zhí)行指定操作,如清理資源;參數(shù)在defer時(shí)立即求值,函數(shù)按后進(jìn)先出(LIFO)順序執(zhí)行;1.多個(gè)defer按聲明逆序執(zhí)行;2.常用于文件關(guān)閉等安全清理;3.可修改命名返回值;4.即使發(fā)生panic也會(huì)執(zhí)行,適合用于recover;5.避免在循環(huán)中濫用defer,防止資源泄漏;正確使用可提升代碼安全性和可讀性。

See all articles