婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 10種Java開發者編寫SQL語句時常見錯誤

10種Java開發者編寫SQL語句時常見錯誤

熱門標簽:廣州人工電銷機器人費用 怎樣把地圖標注導入公司地址 洛陽外呼系統平臺 寧波人工外呼系統有效果嗎 如何在地圖標注自己店鋪 地圖標注一個圓圈怎么用 真人語音電銷機器人 400外呼系統合法 電銷機器人被曝光

Java開發者對于面向對象編程思維與命令行編程思維的協調程度,取決于他們如下幾種能力的水平:

技巧(任何人都可以編寫命令行形式的代碼)
教條(有的人使用“模式 - 模式”的方式,即模式無處不在,并以名字作為標識)
情緒狀況(在初期,真正面向對象形式的代碼比起命令式代碼會更加難懂。)

但是,當Java開發人員編寫SQL語句時,一切都變得不同了。SQL是一種說明式語言,與面向對象思想和命令式思想無關。在SQL語言中,查詢非常容易表達。但它也不是那么容易以最佳或最正確地方式編寫出來。開發人員不僅需要重新思考自己的編程模式,還需要從集合論的角度進行深入思考。

以下是Java開發人員使JDBC或jOOQ編寫SQL語句時,幾種常見的錯誤

1.忘記了NULL

誤解NULL的含義可能是Java開發人員編寫SQL最常犯的錯誤。這有可能是因為NULL也被稱為UNKNOWN,但也有其他的原因。當然如果它只被叫做UNKNOWN,會更容易理解一些。另一個原因是,JDBC在獲取數據,或綁定變量時,SQL中的NULL被映射到Java中的null。這可能會導致人們認為類似Java中null==null的情況,SQL中也存在NULL= NULL。

一個更離奇的誤解NULL的例子是,當NULL謂詞用于行值表達式時。

另一個微妙的問題產生與對NOTIn 反連接中NULL含義的誤解。

解決辦法

不斷的訓練自己。要時刻明確NULL的含義,每次你寫SQL時,都要考慮:

對于NULL來說謂詞是否正確?
NULL是否影響該函數的結果?
2.在Java內存中處理數據

一些Java開發者十分了解SQL特性。偶爾JOIN,零散的UNION,沒什么問題。但如果遇到視窗功能,結果集分組等情況又怎么樣呢?很多Java開發人員會把SQL數據加載到內存,把數據轉換成一些適合的集合類型,以十分冗長的循環結構在集合上執行惱人數學運算(至少在Java 8改進容器之前是這樣的)。

但一些SQL數據庫除了支持SQL標準外,還支持先進的OLAP特性,執行效率更好,且更容易編寫。一個非標準的例子就是甲骨文的MODEL子句。只是讓數據庫進行數據處理過程,將最終獲取的結果加載到Java內存中。因為一些非常聰明的人已經優化了這些昂貴的產品。所以,事實上,通過向OLAP數據庫上進行遷移,您將得到兩個好處:

簡潔。它可能使得在SQL中編寫正確代碼會比在Java中相對容易
性能。該數據庫將可能比你的算法要快。更重要的是,你不必再通過網絡傳輸數百萬條記錄。
解決辦法

每次你在Java中實現以數據為中心的算法時,要試著問問自己:有沒有辦法讓數據庫執行這些工作,而只把結果交付給我?

3.盡量使用UNION,而不是UNION ALL

相對于UNION,UNION ALL需要額外的關鍵字顯得相形見絀。如果在SQL標準已定義如下支持,那將會好很多:

UNION(允許重復)
UNION DISTINCT(去掉重復)
一般很少需要去除重復(有時去重甚至是錯誤的),而且對于具有很多列的大結果集,它往往很慢,因為這兩個子查詢需要排序,每個元組都需要與隨后的元組進行比較。

需要注意的是,即使SQL標準指定了INTERSECTALL和EXCEPTALL,但幾乎沒有任何數據庫實現這些用處不大的操作。

解決辦法

你每次寫到UNION時,要考慮下你是否實際上想寫的是UNIONALL。

4.使用JDBC分頁功能將大量結果分頁

大多數數據庫都支持通過LIMIT.. OFFSET,TOP .. START AT、OFFSET.. FETCH等子句以某種方式對結果進行分頁。在沒有對這些子句的支持下,但仍然有ROWNUM(Oracle)或ROW_NUMBER()OVER()(DB2,SQL Server 2008和更低版本),這比在內存中分頁要快得多。而且這對于大數據集更是明顯。

解決辦法

只要使用那些子句或工具(如jOOQ),可以為你模擬上述分頁子句。

5.將Java內存中實現連接

從SQL的發展的初期,一些開發商在面對SQL連接時仍然有一種不安的感覺。一直存在著一種固有的恐懼---JOIN速度緩慢。如果基于成本的優化器選擇執行嵌套循環,創建一個連接表源之前,加載完整表到數據庫內存,那速度確實十分緩慢。但很這少發生。通過適當的謂詞,約束和索引,MERGEJOIN和 HASHJOIN操作是非常快的。這與正確的元數據相關(我不用再舉Tom Kyte的例子了)。然而,也有仍然可能有不少Java開發人要會從單獨的查詢中加載兩個表到map容器中,在java內存中以某種方式進行連接操作。

解決辦法

如果你從多個步驟的多個表中進行了SELECT操作,那要慎重考慮一下是否可以在一條語句中表達你所需要的查詢功能。
6.使用DISTINCT或UNION從一個笛卡爾積中刪除重復

冗長連接的存在,會導致SQL語句中起作用的關系顯得十分松散。具體地,如果涉及到多列外鍵關系,很有可能忘記在JOINON子句上添加謂詞。這可能會導致重復的記錄,但也許只在特殊情況下。然后一些開發者可能會選擇使用DISTINCT再次刪除這些重復記錄。這種錯誤有三種危害:

可能治標不治本。甚至在某些邊緣情況下,標都治不了
這在有很多列的大結果集上會十分的緩慢。DISTINCT會執行ORDER BY操作來刪除重復。
這在大型笛卡爾積中也十分的緩慢,因為這樣做仍然會導致在內存中加載大量數據。
解決辦法

作為一個經驗法則,當你得到不想要的重復結果時,應該首先檢查你的連接謂詞。因為有可能是在某個地方存在著一個不易察覺的笛卡爾積。

7.不使用MERGE語句

嚴格意義上講,這不是一個真正的錯誤,可能只是對于功能強大的MERGE語句缺乏足夠的認知或存在著某種恐懼而已。有些數據庫包括其他形式的UPSERT 語句,如MySQL的ONDUPLICATE KEY UPDATE子句。但MERGE真的十分強大,最重要的是在數據庫中,它在很大程度上擴展了SQL標準,如SQL Server。

解決辦法

如果你通過鏈接INSERT和UPDATE或鏈接SELECT... FOR UPDATE來實現UPSERTING,那么你要多想一想。拋開與運行條件的風險,你也許可以使用一個簡單的MERGE語句來達到目的。

8.使用了聚合函數,而不是窗體功能

引入窗函數之前,使用GROUPBY子句與投影聚合函數是匯總數據的唯一方式。這在大部分情況下都十分有效,如果聚集后的數據需要由常規的數據進行補充,該分組的查詢可以置于連接子查詢中。

但是,SQL:2003定義了窗口功能,目前很多主流的數據庫廠商也紛紛實現了窗口功能。窗口功能可以聚集結果集中未被分組的數據。事實上,每個窗口的功能支持自身獨立的PARTITIONBY子句,這對于報表類應用是一個非常有用的工具。

使用窗口功能將:

導致更多的可讀性SQL(減少子查詢中非專用GROUP BY子句的存在)
提高性能,作為一個RDBMS很可能更容易優化其窗口功能。
解決辦法

當你在一個子查詢寫一個GROUPBY子句時,仔細想想這是否能用一個窗口函數來完成。

9.使用內存排序法進行間接排序

在SQLORDER BY子句支持多種類型的表達式,包括CASE語句,這對間接排序非常有用。你應該永遠可能在Java內存中對數據進行排序,因為你認為:

SQL排序太慢
SQL排序不能做到這一點
解決辦法

如果你在內存中對任何SQL數據進行排序,請仔細想想,你是否能把排序遷移至數據庫中。這和將分頁遷移至數據庫中的原因一樣。

10 一個接一個的插入大量的記錄

JDBC包含了批處理,而且你應該使用它。面對成千上萬的記錄,切勿為每一條記錄都創建一個新的PreparedStatement來進行插入操作。如果你要將所有記錄都插入到同一個表,使用單一的SQL語句和多個綁定值集合建立一個批處理的INSERT語句。根據您的數據庫和數據庫配置,您可能需要在一定數量的插入的記錄后進行提交,為了保持UNDO日志不過分龐大。

解決辦法

始終批量插入大型數據集。

Java開發者編寫SQL語句時常見的10種錯誤,大家是不是有了大概了解,希望在編寫的過程中一定要特別注意!

您可能感興趣的文章:
  • Java 程序員容易犯的10個SQL錯誤
  • java.sql.SQLException: 內部錯誤: Unable to construct a Datum from the specified input
  • java程序員常見的sql錯誤

標簽:南昌 石家莊 咸寧 東營 晉中 北海 珠海 煙臺

巨人網絡通訊聲明:本文標題《10種Java開發者編寫SQL語句時常見錯誤》,本文關鍵詞  10種,Java,開發者,編寫,SQL,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《10種Java開發者編寫SQL語句時常見錯誤》相關的同類信息!
  • 本頁收集關于10種Java開發者編寫SQL語句時常見錯誤的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    91福利在线导航| 在线电影国产精品| 国产精品每日更新在线播放网址| 91最新地址在线播放| 天天色综合天天| 国产精品毛片大码女人| 欧美大片在线观看| 视频一区二区欧美| 亚洲三级小视频| 久久精品人人做| 欧美丰满少妇xxxxx高潮对白 | 亚洲免费三区一区二区| 久久综合色8888| 欧美一区2区视频在线观看| 一本色道久久综合狠狠躁的推荐| 国产成人午夜片在线观看高清观看| 日韩av一二三| 亚洲一区在线视频观看| 亚洲日韩欧美一区二区在线| 国产视频一区二区在线| 亚洲精品一区二区三区影院| 欧美一区二区日韩一区二区| 欧美日韩中文字幕一区| 欧美在线你懂得| 欧美在线观看一区| 欧美日韩中文另类| 色激情天天射综合网| 不卡高清视频专区| 国产99久久久国产精品| 懂色中文一区二区在线播放| 成人av在线一区二区| 91香蕉视频污在线| 91国偷自产一区二区三区成为亚洲经典| 91免费在线看| 欧美精品三级日韩久久| 精品三级在线看| 国产亚洲1区2区3区| 亚洲激情在线激情| 亚洲成人av福利| 日本中文字幕一区| 久久99热99| 成人小视频在线观看| 日本精品视频一区二区三区| 欧美日韩中文精品| 欧美一区二视频| 精品av综合导航| 日韩理论在线观看| 日日欢夜夜爽一区| 国产一区二区精品久久| 97成人超碰视| 欧美一区二区三区性视频| 26uuu亚洲综合色欧美 | 久久蜜桃一区二区| 国产精品美女久久福利网站| 亚洲国产精品久久久男人的天堂| 日韩成人一区二区三区在线观看| 久久精品99国产精品| 丰满亚洲少妇av| 成人黄色小视频| 91一区二区在线| 欧美日韩久久久一区| 日韩亚洲电影在线| 国产精品成人免费| 另类中文字幕网| 91福利国产精品| 久久久久国产精品麻豆| 亚洲va天堂va国产va久| 丁香激情综合国产| 91福利精品第一导航| 欧美国产禁国产网站cc| 日本午夜精品一区二区三区电影| www.日韩在线| 日韩午夜av一区| 亚洲国产精品人人做人人爽| 成人一区二区三区中文字幕| 日韩欧美中文一区| 一区二区三区在线视频免费观看 | 亚洲国产精品欧美一二99| 国产精品99久| 9191国产精品| 亚洲丝袜美腿综合| 国内精品自线一区二区三区视频| 欧美三级三级三级| 亚洲婷婷综合色高清在线| 国产综合色产在线精品| 色94色欧美sute亚洲线路一ni | 国产精品久久久久婷婷| 麻豆高清免费国产一区| 99r国产精品| 欧美高清在线精品一区| 国产精品99久久久久久有的能看| 日韩欧美一级二级三级| 亚洲最色的网站| 91麻豆高清视频| √…a在线天堂一区| 国产suv精品一区二区三区| 精品福利在线导航| 久久99精品国产麻豆婷婷| 欧美一级片免费看| 天堂久久一区二区三区| 欧美日韩高清影院| 亚洲国产综合91精品麻豆| 91国产精品成人| 一区二区三区中文在线观看| 亚洲人成电影网站色mp4| 99re这里只有精品首页| 中文字幕亚洲一区二区av在线| 国产+成+人+亚洲欧洲自线| 国产女人水真多18毛片18精品视频| 国产乱人伦精品一区二区在线观看| 精品国产制服丝袜高跟| 国产裸体歌舞团一区二区| 26uuu欧美| 成人福利视频在线| 亚洲综合小说图片| 717成人午夜免费福利电影| 日本va欧美va精品发布| 欧美大片顶级少妇| 国产成人免费在线视频| 亚洲三级在线免费观看| 成人网在线播放| 国产亚洲一本大道中文在线| 国产乱码一区二区三区| 国产精品久久久久影院色老大 | 99v久久综合狠狠综合久久| 专区另类欧美日韩| 精品视频在线免费| 久久精品国产亚洲5555| 中文字幕国产一区二区| 91激情在线视频| 奇米精品一区二区三区四区| 久久人人超碰精品| 暴力调教一区二区三区| 午夜精品久久一牛影视| 精品不卡在线视频| www.日韩在线| 日本不卡在线视频| 高清免费成人av| 偷拍自拍另类欧美| 久久精品视频一区二区三区| 色域天天综合网| 国内精品久久久久影院色| 亚洲欧美在线视频观看| 91精品在线麻豆| aaa亚洲精品一二三区| 午夜一区二区三区视频| 久久精品视频网| 91精品欧美综合在线观看最新| 国产精品亚洲一区二区三区妖精| 最新不卡av在线| 精品国产一区二区三区久久久蜜月| av动漫一区二区| 久热成人在线视频| 尤物在线观看一区| 国产欧美一区二区精品婷婷| 欧美日韩一区二区三区免费看| 精品在线观看视频| 亚洲激情男女视频| 欧美韩日一区二区三区四区| 欧美久久婷婷综合色| 色婷婷一区二区| 99精品视频在线播放观看| 韩国精品久久久| 美国十次综合导航| 日本不卡高清视频| 午夜精品久久一牛影视| 一区二区三区精品在线观看| 国产精品乱码一区二三区小蝌蚪| 久久奇米777| 欧美大片在线观看一区二区| 欧美亚洲国产怡红院影院| 国产一区二区在线观看视频| 日韩精品一级二级| 亚洲国产成人va在线观看天堂| 亚洲天堂福利av| 国产欧美一区二区精品忘忧草| 欧美电视剧在线看免费| 日韩亚洲欧美在线| 欧美日韩性生活| 欧美视频在线观看一区二区| 一本一本大道香蕉久在线精品| 成人久久久精品乱码一区二区三区| 在线电影院国产精品| 日韩欧美在线1卡| 欧美少妇xxx| 懂色av一区二区在线播放| 精品一区二区在线看| 亚洲乱码国产乱码精品精可以看| 欧美日韩国产123区| 婷婷一区二区三区| 亚洲一区日韩精品中文字幕| 亚洲美女区一区| 一区二区三区欧美日| 亚洲精品美国一| 亚洲一区二区美女| 尤物av一区二区| 日韩**一区毛片| 丝袜诱惑制服诱惑色一区在线观看| 亚洲aaa精品| 国产精选一区二区三区|