91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Java程序員最容易犯的10個SQL錯誤是哪些

電子工程師 ? 來源:OSCHINA ? 作者:OSCHINA ? 2021-06-07 15:59 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Java程序員編程時需要混合面向對象思維和一般命令式編程的方法,能否完美的將兩者結合起來完全得依靠編程人員的水準:

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

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

心境(首先,要寫個好的面向對象程序是比命令式程序難的多,你得花費一些功夫)

但當Java程序員寫SQL語句時,一切都不一樣了。SQL是說明性語言而非面向對象或是命令式編程語言。在SQL中要寫個查詢語句是很簡單的。但在Java里類似的語句卻不容易,因為程序員不僅要反復考慮編程范式,而且也要考慮算法的問題。

下面是Java程序員在寫SQL時常犯的10個錯誤(沒有特定的順序)。

1、忘掉NULL

Java程序員寫SQL時對NULL的誤解可能是最大的錯誤。也許是因為(并非唯一理由)NULL也稱作UNKNOWN。如果被稱作 UNKNOWN,這還好理解些。另一個原因是,當你從數(shù)據(jù)庫拿東西或是綁定變量時,JDBC將SQL NULL 和Java中的null對應了起來。這樣導致了NULL = NULL(SQL)和null=null(Java)的誤解。

對于NULL最大的誤解是當NULL被用作行值表達式完整性約束條件時。另一個誤解出現(xiàn)在對于NULL 在 NOT IN anti-joins的應用中。

解決方法:

好好的訓練你自己。當你寫SQL時要不停得想到NULL的用法:

這個NULL完整性約束條件是正確的?

NULL是否影響到結果?

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

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

但是一些SQL數(shù)據(jù)庫支持先進的(而且是SQL標準支持的)OLAP特性,這一特性表現(xiàn)更好而且寫起來也更加方便。一個(并不怎么標準的)例子就 是Oracle超棒的MODEL分句。只讓數(shù)據(jù)庫來做處理然后只把結果帶到Java內存中吧。因為畢竟所有非常聰明的家伙已經對這些昂貴的產品進行了優(yōu) 化。因此實際上,通過將OLAP移到數(shù)據(jù)庫,你將獲得一下兩項好處:

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

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

解決方法:

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

3、使用UNION 代替UNION ALL

UNION ALL(允許重復)

UNION (去除了重復)

移除重復行不僅很少需要(有時甚至是錯的),而且對于帶很多行的大數(shù)據(jù)集合會相當慢,因為兩個子select需要排序,而且每個元組也需要和它的子序列元組比較。

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

解決方法:

每次寫UNION語句時,考慮實際上是否需要UNION ALL語句。

4、通過JDBC分頁技術給大量的結果進行分頁操作

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

解決方法:

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

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

從SQL的初期開始,當在SQL中使用JOIN語句時,一些開發(fā)者仍舊有不安的感覺。這是源自對加入JOIN后會變慢的固有恐懼。

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

解決方法:

假如你在各個步驟中有從各種表的查詢操作,好好想想是否可以表達你的查詢操作在單條語句中。

6、在一個臨時的笛卡爾積集合中使用 DISTINCT 或 UNION 消除重復項

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

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

對具有很多列的龐大的結果集合來說它很慢。DISTINCT要執(zhí)行ORDER BY操作來消除重復。

對龐大的笛卡爾積集合來說它很慢,還是需要加載很多的數(shù)據(jù)到內存中。

解決方法:

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

7、不使用MERGE語句

這并不是一個過失,但是可能是缺少知識或者對于強悍的MERGE語句信心不足。一些數(shù)據(jù)庫理解其它形式的更新插入(UPSERT)語句, 如 MYSQL的重復主鍵更新語句,但是MERGE在數(shù)據(jù)庫中確是很強大,很重要,以至于大肆擴展SQL標準,例如SQL SERVER。

解決方法:

如果你使用像聯(lián)合INSERT和UPDATE或者聯(lián)合SELECT 。。 FOR UPDATE然后在INSERT或UPDATE等更新插入時,請三思。你完全可以使用一個更簡單的MERGE語句來遠離冒險競爭條件。

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

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

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

使用窗口函數(shù):

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

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

解決方法:

當你在子查詢中使用GROUP BY語句時,請再三考慮是否可以使用窗口函數(shù)完成。

9、使用內存間接排序

SQL的ORDER BY語句支持很多類型的表達式,包括CASE語句,對于間接排序十分有用。你可能重來不會在Java內存中排序數(shù)據(jù),因為你會想:

SQL排序很慢

SQL排序辦不到

解決方法:

如果你在內存中排序任何SQL數(shù)據(jù),請再三考慮,是否不能在數(shù)據(jù)庫中排序。這對于數(shù)據(jù)庫分頁數(shù)據(jù)十分有用。

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

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

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

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

編輯:jq

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 數(shù)據(jù)

    關注

    8

    文章

    7335

    瀏覽量

    94761
  • JAVA
    +關注

    關注

    20

    文章

    3001

    瀏覽量

    116426
  • SQL
    SQL
    +關注

    關注

    1

    文章

    789

    瀏覽量

    46700
  • null
    +關注

    關注

    0

    文章

    19

    瀏覽量

    4306

原文標題:Java程序員常犯的 10 個 SQL 錯誤!

文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    嵌入式軟件開發(fā)的 10 技巧分享

    資源來演示狀態(tài)機理論和算法。 技巧 3:避免使用全局變量 在函數(shù)式編程的年代,函數(shù)要先于形式,程序員的唯一目標是盡可能地讓程序按預期方式快速運行,而不用考慮程序結構或可重用性。這種編程范式會毫無顧慮
    發(fā)表于 12-25 06:04

    大理的AI野心藏不住了——風花雪月中千名程序員探討人工智能

    2025 年12月4日至6日第二屆CCF程序員大會暨大理人工智能與應用國際開發(fā)者大會在大理圓滿落幕。
    的頭像 發(fā)表于 12-24 17:45 ?716次閱讀
    大理的AI野心藏不住了——風花雪月中千名<b class='flag-5'>程序員</b>探討人工智能

    程序員最常見謊言

    了。 28我已經測試過了,這個功能沒問題,可以上線了。 29別擔心,這個問題很快就能解決。 30代碼快寫完了,已經完成 90% 了 。 希望大家對程序員多一些容忍以及諒解! 各位程序員你們都被我說中了哪些?說說你們的觀點
    發(fā)表于 12-10 08:24

    奔赴熱AI,碼力全開!Talkweb House@1024程序員日系列活動圓滿收官

    1024程序員日”系列活動至此劃上了一圓滿句號。本屆1024程序員節(jié)以“AI構建世界,智能引領未來”為主題,廣邀技術大咖、產業(yè)領袖、企業(yè)代表與全球開發(fā)者齊聚星城
    的頭像 發(fā)表于 10-27 18:59 ?769次閱讀
    奔赴熱AI,碼力全開!Talkweb House@1024<b class='flag-5'>程序員</b>日系列活動圓滿收官

    開鴻智谷“以賽促學、以賽選才”|1024程序員節(jié)暨開源鴻蒙構建大會圓滿落幕!

    10月24日,由開鴻智谷聯(lián)合主辦的長沙1024程序員節(jié)暨開源鴻蒙構建大會在長沙圓滿落幕。本次活動以“湘聚長沙,共赴熱AI”為主題,通過技術分享與實戰(zhàn)競賽相結合的方式,著力培養(yǎng)“開源鴻蒙+AI”領域
    的頭像 發(fā)表于 10-27 17:58 ?702次閱讀
    開鴻智谷“以賽促學、以賽選才”|1024<b class='flag-5'>程序員</b>節(jié)暨開源鴻蒙構建大會圓滿落幕!

    AI技術在工程設計的應用

    在不需要硬件交互的純軟件項目中,ChatGPT和Gemini等大語言模型(LLM)可以幫助程序員以前所未有的速度加速開發(fā)進程。這種輔助通常包括在開發(fā)人員編寫代碼時提供補全建議,或在排查錯誤和語法錯誤時提供故障排除建議——這些都是
    的頭像 發(fā)表于 09-23 16:21 ?884次閱讀
    AI技術在工程設計的應用

    Java效率提升指南:5Java工具選型建議及Perforce JRebel和XRebel介紹

    企業(yè)級Java環(huán)境越來越復雜,真正的破局點,可能不在“人”,而在于“工具”。5實用建議,幫你理清Java工具的選型思路。
    的頭像 發(fā)表于 09-11 13:59 ?1485次閱讀
    <b class='flag-5'>Java</b>效率提升指南:5<b class='flag-5'>個</b><b class='flag-5'>Java</b>工具選型建議及Perforce JRebel和XRebel介紹

    SQL 通用數(shù)據(jù)類型

    data type. SQL 開發(fā)人員必須在創(chuàng)建 SQL 表時決定表中的每個列將要存儲的數(shù)據(jù)的類型。數(shù)據(jù)類型是一標簽,是便于 SQL 了解每個列期望存儲什么類型的數(shù)據(jù)的指南,它也標
    的頭像 發(fā)表于 08-18 09:46 ?711次閱讀

    避雷!樹莓派初學者常犯的5錯誤!

    如果你剛剛入手樹莓派,你就會知道它潛力無窮,幾乎能實現(xiàn)你想到的任何功能。然而,這種自由也讓你可能在不知不覺中做出對系統(tǒng)有害的操作。在本文中,我將介紹要避免哪些錯誤。初學者最常犯的錯誤包括:損壞SD
    的頭像 發(fā)表于 07-22 17:16 ?1329次閱讀
    避雷!樹莓派初學者常犯的5<b class='flag-5'>個</b><b class='flag-5'>錯誤</b>!

    程序設計與數(shù)據(jù)結構

    的地址)出發(fā),采用推導的方式,深入淺出的分析了廣大C程序員學習和開發(fā)中遇到的難點。 2. 從方法論的高度對C語言在數(shù)據(jù)結構和算法方面的應用進行了深入講解和闡述。 3. 講解了絕大多數(shù)C程序員開發(fā)
    發(fā)表于 05-13 16:45

    Java開發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多Java開發(fā)者在用?

    Perforce JRebel是一款Java開發(fā)效率工具,旨在幫助java開發(fā)人員更快地編寫更好的應用程序。JRebel可即時重新加載對代碼的修改,無需重啟或重新部署應用程序,就能讓開
    的頭像 發(fā)表于 04-27 13:44 ?852次閱讀
    <b class='flag-5'>Java</b>開發(fā)者必備的效率工具——Perforce JRebel是什么?為什么很多<b class='flag-5'>Java</b>開發(fā)者在用?

    在工業(yè)自動化中使用固態(tài)繼電器時應避免的5錯誤

    固態(tài)繼電器(SSR)已成為工業(yè)自動化的無名英雄。它們安靜、可靠、速度快——這是繼電器應具備的所有特點。但就像高科技駕駛艙中的新手飛行員一樣,即使是經驗豐富的工程師在使用SSR時也會常見錯誤。本文讓我們來看看應如何避免在工業(yè)自動化中使用固態(tài)繼電器時應避免的5
    的頭像 發(fā)表于 04-20 11:42 ?706次閱讀

    計算機網絡排錯思路總結

    明人不說暗話,這篇文章我們來聊一非常有用,同時也是程序員必備的技能,那就是網絡排錯思路大總結。
    的頭像 發(fā)表于 04-01 17:32 ?890次閱讀
    計算機網絡排錯思路總結

    如何在 樹莓派 上編寫和運行 C 語言程序?

    ,一本很好的書是BrianKernighan和DennisRitchie所著的《TheCProgrammingLanguage》。這本書對經驗豐富的程序員和想學習C語
    的頭像 發(fā)表于 03-25 09:28 ?1156次閱讀
    如何在 樹莓派 上編寫和運行 C 語言<b class='flag-5'>程序</b>?

    零基礎入門:如何在樹莓派上編寫和運行Python程序?

    是一種非常有用的編程語言,其語法易于閱讀,允許程序員使用比匯編、C或Java等語言更少的代碼行。Python編程語言最初實際上是作為Linux的腳本語言而開發(fā)的。Py
    的頭像 發(fā)表于 03-25 09:27 ?2032次閱讀
    零基礎入門:如何在樹莓派上編寫和運行Python<b class='flag-5'>程序</b>?