一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Java程序員最容易犯的10個(gè)SQL錯(cuò)誤是哪些

電子工程師 ? 來(lái)源:OSCHINA ? 作者:OSCHINA ? 2021-06-07 15:59 ? 次閱讀

Java程序員編程時(shí)需要混合面向?qū)ο笏季S和一般命令式編程的方法,能否完美的將兩者結(jié)合起來(lái)完全得依靠編程人員的水準(zhǔn):

技能(任何人都能容易學(xué)會(huì)命令式編程)

模式(有些人用“模式-模式”,舉個(gè)例子,模式可以應(yīng)用到任何地方,而且都可以歸為某一類模式)

心境(首先,要寫(xiě)個(gè)好的面向?qū)ο蟪绦蚴潜让钍匠绦螂y的多,你得花費(fèi)一些功夫)

但當(dāng)Java程序員寫(xiě)SQL語(yǔ)句時(shí),一切都不一樣了。SQL是說(shuō)明性語(yǔ)言而非面向?qū)ο蠡蚴敲钍骄幊陶Z(yǔ)言。在SQL中要寫(xiě)個(gè)查詢語(yǔ)句是很簡(jiǎn)單的。但在Java里類似的語(yǔ)句卻不容易,因?yàn)槌绦騿T不僅要反復(fù)考慮編程范式,而且也要考慮算法的問(wèn)題。

下面是Java程序員在寫(xiě)SQL時(shí)常犯的10個(gè)錯(cuò)誤(沒(méi)有特定的順序)。

1、忘掉NULL

Java程序員寫(xiě)SQL時(shí)對(duì)NULL的誤解可能是最大的錯(cuò)誤。也許是因?yàn)椋ú⒎俏ㄒ焕碛桑㎞ULL也稱作UNKNOWN。如果被稱作 UNKNOWN,這還好理解些。另一個(gè)原因是,當(dāng)你從數(shù)據(jù)庫(kù)拿東西或是綁定變量時(shí),JDBC將SQL NULL 和Java中的null對(duì)應(yīng)了起來(lái)。這樣導(dǎo)致了NULL = NULL(SQL)和null=null(Java)的誤解。

對(duì)于NULL最大的誤解是當(dāng)NULL被用作行值表達(dá)式完整性約束條件時(shí)。另一個(gè)誤解出現(xiàn)在對(duì)于NULL 在 NOT IN anti-joins的應(yīng)用中。

解決方法:

好好的訓(xùn)練你自己。當(dāng)你寫(xiě)SQL時(shí)要不停得想到NULL的用法:

這個(gè)NULL完整性約束條件是正確的?

NULL是否影響到結(jié)果?

2、在Java內(nèi)存中處理數(shù)據(jù)

很少有Java開(kāi)發(fā)者能將SQL理解的很好。偶爾使用的JOIN,還有古怪的UNION,好吧,但是對(duì)于窗口函數(shù)呢?還有對(duì)集合進(jìn)行分組呢?許多 的Java開(kāi)發(fā)者將SQL數(shù)據(jù)加載到內(nèi)存中,將這些數(shù)據(jù)轉(zhuǎn)換成某些相近的集合類型,然后再那些集合上面使用邊界循環(huán)控制結(jié)構(gòu)(至少在Java8的集合升級(jí) 以前)執(zhí)行令人生厭的數(shù)學(xué)運(yùn)算。

但是一些SQL數(shù)據(jù)庫(kù)支持先進(jìn)的(而且是SQL標(biāo)準(zhǔn)支持的)OLAP特性,這一特性表現(xiàn)更好而且寫(xiě)起來(lái)也更加方便。一個(gè)(并不怎么標(biāo)準(zhǔn)的)例子就 是Oracle超棒的MODEL分句。只讓數(shù)據(jù)庫(kù)來(lái)做處理然后只把結(jié)果帶到Java內(nèi)存中吧。因?yàn)楫吘顾蟹浅B斆鞯募一镆呀?jīng)對(duì)這些昂貴的產(chǎn)品進(jìn)行了優(yōu) 化。因此實(shí)際上,通過(guò)將OLAP移到數(shù)據(jù)庫(kù),你將獲得一下兩項(xiàng)好處:

便利性。這比在Java中編寫(xiě)正確的SQL可能更加的容易。

性能表現(xiàn)。數(shù)據(jù)庫(kù)應(yīng)該比你的算法處理起來(lái)更加快。而且更加重要的是,你不必再去傳遞數(shù)百萬(wàn)條記錄了。

解決方法:

每次你使用Java實(shí)現(xiàn)一個(gè)以數(shù)據(jù)為中心的算法時(shí),問(wèn)問(wèn)自己:有沒(méi)有一種方法可以讓數(shù)據(jù)庫(kù)代替為我做這種麻煩事。

3、使用UNION 代替UNION ALL

UNION ALL(允許重復(fù))

UNION (去除了重復(fù))

移除重復(fù)行不僅很少需要(有時(shí)甚至是錯(cuò)的),而且對(duì)于帶很多行的大數(shù)據(jù)集合會(huì)相當(dāng)慢,因?yàn)閮蓚€(gè)子select需要排序,而且每個(gè)元組也需要和它的子序列元組比較。

注意即使SQL標(biāo)準(zhǔn)規(guī)定了INTERSECT ALL和EXCEPT ALL,很少數(shù)據(jù)庫(kù)會(huì)實(shí)現(xiàn)這些沒(méi)用的集合操作符。MySQL 系列面試題都整理好了,微信搜索Java技術(shù)棧,在后臺(tái)發(fā)送:面試,可在線刷題。

解決方法:

每次寫(xiě)UNION語(yǔ)句時(shí),考慮實(shí)際上是否需要UNION ALL語(yǔ)句。

4、通過(guò)JDBC分頁(yè)技術(shù)給大量的結(jié)果進(jìn)行分頁(yè)操作

大部分的數(shù)據(jù)庫(kù)都會(huì)支持一些分頁(yè)命令實(shí)現(xiàn)分頁(yè)效果,譬如LIMIT..OFFSET,TOP..START AT,OFFSET..FETCH語(yǔ)句等。即使沒(méi)有支持這些語(yǔ)句的數(shù)據(jù)庫(kù),仍有可能對(duì)ROWNUM(Oracle)或者是ROW NUMBER()、OVER()過(guò)濾(DB2、SQL Server2008等),這些比在內(nèi)存中實(shí)現(xiàn)分頁(yè)更快速。在處理大量數(shù)據(jù)中,效果尤其明顯。

解決方法:

僅僅使用這些語(yǔ)句,那么一個(gè)工具(例如JOOQ)就可以模擬這些語(yǔ)句的操作。

5、在Java內(nèi)存中加入數(shù)據(jù)

從SQL的初期開(kāi)始,當(dāng)在SQL中使用JOIN語(yǔ)句時(shí),一些開(kāi)發(fā)者仍舊有不安的感覺(jué)。這是源自對(duì)加入JOIN后會(huì)變慢的固有恐懼。

假如基于成本的 優(yōu)化選擇去實(shí)現(xiàn)嵌套循環(huán),在創(chuàng)建一張連接表源前,可能加載所有的表在數(shù)據(jù)庫(kù)內(nèi)存中,這可能是真的。但是這事發(fā)生的概率太低了。通過(guò)合適的預(yù)測(cè),約束和索 引,合并連接和哈希連接的操作都是相當(dāng)?shù)目?。這完全是是關(guān)于正確元數(shù)據(jù)(在這里我不能夠引用Tom Kyte的太多)。而且,可能仍然有不少的Java開(kāi)發(fā)人員加載兩張表通過(guò)分開(kāi)查詢到一個(gè)映射中,并且在某種程度上把他們加到了內(nèi)存當(dāng)中。

解決方法:

假如你在各個(gè)步驟中有從各種表的查詢操作,好好想想是否可以表達(dá)你的查詢操作在單條語(yǔ)句中。

6、在一個(gè)臨時(shí)的笛卡爾積集合中使用 DISTINCT 或 UNION 消除重復(fù)項(xiàng)

通過(guò)復(fù)雜的連接,人們可能會(huì)對(duì)SQL語(yǔ)句中扮演關(guān)鍵角色的所有關(guān)系失去概念。特別的,如果這涉及到多列外鍵關(guān)系的話,很有可能會(huì)忘記在JOIN 。。 ON子句中增加相關(guān)的判斷。這會(huì)導(dǎo)致重復(fù)的記錄,但或許只是在特殊的情況下。有些開(kāi)發(fā)者因此可能選擇DISTINCT來(lái)消除這些重復(fù)記錄。從三個(gè)方面來(lái)說(shuō) 這是錯(cuò)誤的:

它(也許)解決了表面癥狀但并沒(méi)有解決問(wèn)題。它也有可能無(wú)法解決極端情況下的癥狀。

對(duì)具有很多列的龐大的結(jié)果集合來(lái)說(shuō)它很慢。DISTINCT要執(zhí)行ORDER BY操作來(lái)消除重復(fù)。

對(duì)龐大的笛卡爾積集合來(lái)說(shuō)它很慢,還是需要加載很多的數(shù)據(jù)到內(nèi)存中。

解決方法:

根據(jù)經(jīng)驗(yàn),如果你獲得了不需要的重復(fù)記錄,還是檢查你的JOIN判斷吧??赡茉谀硞€(gè)地方有一個(gè)很難覺(jué)察的笛卡爾積集合。

7、不使用MERGE語(yǔ)句

這并不是一個(gè)過(guò)失,但是可能是缺少知識(shí)或者對(duì)于強(qiáng)悍的MERGE語(yǔ)句信心不足。一些數(shù)據(jù)庫(kù)理解其它形式的更新插入(UPSERT)語(yǔ)句, 如 MYSQL的重復(fù)主鍵更新語(yǔ)句,但是MERGE在數(shù)據(jù)庫(kù)中確是很強(qiáng)大,很重要,以至于大肆擴(kuò)展SQL標(biāo)準(zhǔn),例如SQL SERVER。

解決方法:

如果你使用像聯(lián)合INSERT和UPDATE或者聯(lián)合SELECT 。。 FOR UPDATE然后在INSERT或UPDATE等更新插入時(shí),請(qǐng)三思。你完全可以使用一個(gè)更簡(jiǎn)單的MERGE語(yǔ)句來(lái)遠(yuǎn)離冒險(xiǎn)競(jìng)爭(zhēng)條件。

8、使用聚合函數(shù)代替窗口函數(shù)(window functions)

在介紹窗口函數(shù)之前,在SQL中聚合數(shù)據(jù)意味著使用GROUP BY語(yǔ)句與聚合函數(shù)相映射。在很多情形下都工作得很好,如聚合數(shù)據(jù)需要濃縮常規(guī)數(shù)據(jù),那么就在join子查詢中使用group查詢。

但是在SQL2003中定義了窗口函數(shù),這個(gè)在很多主流數(shù)據(jù)庫(kù)都實(shí)現(xiàn)了它。窗口函數(shù)能夠在結(jié)果集上聚合數(shù)據(jù),但是卻沒(méi)有分組。事實(shí)上,每個(gè)窗口函數(shù)都有自己的、獨(dú)立的PARTITION BY語(yǔ)句,這個(gè)工具對(duì)于顯示報(bào)告太好了。

使用窗口函數(shù):

使SQL更易讀(但在子查詢中沒(méi)有GROUP BY語(yǔ)句專業(yè))

提升性能,像關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)能夠更容易優(yōu)化窗口函數(shù)

解決方法:

當(dāng)你在子查詢中使用GROUP BY語(yǔ)句時(shí),請(qǐng)?jiān)偃紤]是否可以使用窗口函數(shù)完成。

9、使用內(nèi)存間接排序

SQL的ORDER BY語(yǔ)句支持很多類型的表達(dá)式,包括CASE語(yǔ)句,對(duì)于間接排序十分有用。你可能重來(lái)不會(huì)在Java內(nèi)存中排序數(shù)據(jù),因?yàn)槟銜?huì)想:

SQL排序很慢

SQL排序辦不到

解決方法:

如果你在內(nèi)存中排序任何SQL數(shù)據(jù),請(qǐng)?jiān)偃紤],是否不能在數(shù)據(jù)庫(kù)中排序。這對(duì)于數(shù)據(jù)庫(kù)分頁(yè)數(shù)據(jù)十分有用。

10、一條一條地插入大量記錄

JDBC“懂”批處理(batch),你應(yīng)該不會(huì)忘了它。不要使用INSERT語(yǔ)句來(lái)一條一條的出入成千上萬(wàn)的記錄,(因?yàn)椋┟看味紩?huì)創(chuàng)建一個(gè)新 的PreparedStatement對(duì)象。如果你的所有記錄都插入到同一個(gè)表時(shí),那么就創(chuàng)建一個(gè)帶有一條SQL語(yǔ)句以及附帶很多值集合的插入批處理語(yǔ) 句。你可能需要在達(dá)到一定量的插入記錄后才提交來(lái)保證UNDO日志瘦小,這依賴于你的數(shù)據(jù)庫(kù)和數(shù)據(jù)庫(kù)設(shè)置。

原文來(lái)源:http://blog.jooq.org/ 譯者:LianyouCQ, LeoXu, yale8848, 開(kāi)源中國(guó)駐聯(lián)合國(guó)理事, super0555

譯文:https://www.oschina.net/translate/10-common-mistakes-java-developers-make-when-writing-sql

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)
    +關(guān)注

    關(guān)注

    8

    文章

    7233

    瀏覽量

    90772
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2983

    瀏覽量

    106524
  • SQL
    SQL
    +關(guān)注

    關(guān)注

    1

    文章

    779

    瀏覽量

    44714
  • null
    +關(guān)注

    關(guān)注

    0

    文章

    19

    瀏覽量

    4069

原文標(biāo)題:Java程序員常犯的 10 個(gè) SQL 錯(cuò)誤!

文章出處:【微信號(hào):AndroidPush,微信公眾號(hào):Android編程精選】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Devart::dbForge SQL Complete讓生產(chǎn)力上一個(gè)臺(tái)階

    SQL編碼助手,適用于SSMS 和VS 該工具提供上下文感知的代碼補(bǔ)全,使SQL開(kāi)發(fā)人員和數(shù)據(jù)庫(kù)管理能夠更快地編寫(xiě)代碼。 SQL Complet包含許多實(shí)用的功能,這些功能是專門為提
    的頭像 發(fā)表于 01-14 11:09 ?442次閱讀
    Devart::dbForge <b class='flag-5'>SQL</b> Complete讓生產(chǎn)力上一<b class='flag-5'>個(gè)</b>臺(tái)階

    阿里云升級(jí)通義靈碼AI程序員,全面上線

    近日,阿里云宣布其備受矚目的通義靈碼AI程序員已正式全面上線,為開(kāi)發(fā)者帶來(lái)更為強(qiáng)大和便捷的編程輔助工具。 此次上線的通義靈碼AI程序員,在功能上實(shí)現(xiàn)了全面升級(jí)。現(xiàn)在,它支持VS Code
    的頭像 發(fā)表于 01-09 11:16 ?546次閱讀

    TMS320C6000程序員指南

    電子發(fā)燒友網(wǎng)站提供《TMS320C6000程序員指南.pdf》資料免費(fèi)下載
    發(fā)表于 12-24 17:19 ?0次下載
    TMS320C6000<b class='flag-5'>程序員</b>指南

    TMS320C55x DSP CPU程序員參考補(bǔ)充

    電子發(fā)燒友網(wǎng)站提供《TMS320C55x DSP CPU程序員參考補(bǔ)充.pdf》資料免費(fèi)下載
    發(fā)表于 12-21 11:36 ?0次下載
    TMS320C55x DSP CPU<b class='flag-5'>程序員</b>參考補(bǔ)充

    UCD3138A64/UCD3138128程序員手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《UCD3138A64/UCD3138128程序員手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 12-09 14:42 ?0次下載
    UCD3138A64/UCD3138128<b class='flag-5'>程序員</b>手冊(cè)

    機(jī)械革命發(fā)布CODE AI程序員

    近日,英特爾新質(zhì)生產(chǎn)力技術(shù)生態(tài)大會(huì)在成都舉行,機(jī)械革命作為重要參展商帶來(lái)了多款明星產(chǎn)品引爆全場(chǎng)!其中更是在AI PC軟件生態(tài)產(chǎn)品發(fā)布分論壇上,Intel、智譜、機(jī)械革命三方聯(lián)合發(fā)布了專為程序員設(shè)計(jì)的CODE AI程序員本,成為本次大會(huì)的一大亮點(diǎn)。
    的頭像 發(fā)表于 11-30 10:34 ?860次閱讀

    Linux驅(qū)動(dòng)程序程序員指南

    電子發(fā)燒友網(wǎng)站提供《Linux驅(qū)動(dòng)程序程序員指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-22 15:53 ?0次下載
    Linux驅(qū)動(dòng)<b class='flag-5'>程序</b><b class='flag-5'>程序員</b>指南

    SQL錯(cuò)誤代碼及解決方案

    SQL數(shù)據(jù)庫(kù)開(kāi)發(fā)和管理中,常見(jiàn)的錯(cuò)誤代碼及其解決方案可以歸納如下: 一、語(yǔ)法錯(cuò)誤(Syntax Errors) 錯(cuò)誤代碼 :無(wú)特定代碼,但通常會(huì)在
    的頭像 發(fā)表于 11-19 10:21 ?5626次閱讀

    C++新手容易的十個(gè)編程錯(cuò)誤

    簡(jiǎn)單的總結(jié)一下?C++ 新手容易的一些編程錯(cuò)誤,給新人們提供一個(gè)參考。 1 有些關(guān)鍵字在 cpp 文件中多寫(xiě)了 對(duì)于 C++ 類,一些關(guān)鍵字只要寫(xiě)在 .h 中就好,cpp 中就不用再
    的頭像 發(fā)表于 11-15 12:42 ?830次閱讀

    AI編程工具會(huì)不會(huì)搶程序員飯碗

    AI編程工具可輔助編程,減少手動(dòng)編碼,提升效率,對(duì)程序員有積極影響也有挑戰(zhàn)。程序員需深化技能、拓寬知識(shí)應(yīng)對(duì)。長(zhǎng)遠(yuǎn)看,AI與人類程序員將共生共榮。
    的頭像 發(fā)表于 11-08 10:17 ?431次閱讀

    第五屆長(zhǎng)沙·中國(guó)1024程序員節(jié)開(kāi)幕

    據(jù)官方媒體報(bào)道,10月24日;? 第五屆長(zhǎng)沙·中國(guó)1024程序員節(jié)在湖南湘江新區(qū)開(kāi)幕;本次中國(guó)1024程序員節(jié)以“智能應(yīng)用新生態(tài)”為主題。設(shè)置有岳麓對(duì)話、技術(shù)英雄會(huì)、主題峰會(huì)及賽事、展覽等活動(dòng),一場(chǎng)
    的頭像 發(fā)表于 10-25 15:42 ?386次閱讀

    京東上萬(wàn)程序員都AI用它!

    對(duì)大模型生成代碼進(jìn)行智能修復(fù),為程序員開(kāi)啟代碼漏洞修復(fù)的“自動(dòng)駕駛”模式,不但減少人工接入、提高工作效率,更為企業(yè)抵御內(nèi)外部各種攻擊構(gòu)建起一道堅(jiān)固的安全屏障,確保業(yè)務(wù)的連續(xù)性和穩(wěn)定性。 JoyCoder是京東云自主研發(fā)的一款輔助開(kāi)發(fā)人員
    的頭像 發(fā)表于 07-17 16:29 ?395次閱讀
    京東上萬(wàn)<b class='flag-5'>程序員</b>都AI用它!

    程序員節(jié)視頻創(chuàng)意大賽,用串口屏贏取千元大獎(jiǎng)

    10月24日,程序員專屬的節(jié)日里,我們盛大開(kāi)啟“程序員節(jié)視頻創(chuàng)意大賽”特別活動(dòng)!這不僅是一場(chǎng)視覺(jué)的盛宴,更是智慧與創(chuàng)意的璀璨碰撞。我們誠(chéng)摯邀請(qǐng)每一位程序員及編程愛(ài)好者,拿起你的鏡頭,記
    的頭像 發(fā)表于 07-08 10:38 ?72次閱讀
    <b class='flag-5'>程序員</b>節(jié)視頻創(chuàng)意大賽,用串口屏贏取千元大獎(jiǎng)

    程序員節(jié)視頻創(chuàng)意盛宴,邀您共襄盛舉!

    10月24日,程序員專屬的節(jié)日里,我們盛大開(kāi)啟“程序員節(jié)視頻創(chuàng)意大賽”特別活動(dòng)!這不僅是一場(chǎng)視覺(jué)的盛宴,更是智慧與創(chuàng)意的璀璨碰撞。我們誠(chéng)摯邀請(qǐng)每一位程序員及編程愛(ài)好者,拿起你的鏡頭,記
    的頭像 發(fā)表于 07-04 09:00 ?67次閱讀
    <b class='flag-5'>程序員</b>節(jié)視頻創(chuàng)意盛宴,邀您共襄盛舉!

    甲骨文發(fā)布AI編程助手,助用戶編寫(xiě)Java、SQL程序

    據(jù)悉,Oracle Code Assist基于甲骨文先進(jìn)的云計(jì)算平臺(tái)——Oracle Cloud Infrastructure (OCI)構(gòu)建,重點(diǎn)優(yōu)化各項(xiàng)Java、SQL程序以及OCI應(yīng)用開(kāi)發(fā)環(huán)節(jié)。
    的頭像 發(fā)表于 05-13 10:19 ?782次閱讀