成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL中的n+1次select語句查詢問題

數(shù)據(jù)庫 SQL Server
select語句的數(shù)目太多,需要頻繁的訪問數(shù)據(jù)庫,會(huì)影響檢索性能。如果需要查詢n個(gè)Customer對(duì)象,那么必須執(zhí)行n+1次select查詢語句。這就是經(jīng)典的n+1次select查詢問題。

如果當(dāng)SQL數(shù)據(jù)庫中select語句數(shù)目過多,就會(huì)影響數(shù)據(jù)庫的性能,如果需要查詢n個(gè)Customer對(duì)象,那么必須執(zhí)行n+1次select查詢語句,下文就將為您講解這個(gè)n+1次select查詢問題。

在Session的緩存中存放的是相互關(guān)聯(lián)的對(duì)象圖。默認(rèn)情況下,當(dāng)Hibernate從數(shù)據(jù)庫中加載Customer對(duì)象時(shí),會(huì)同時(shí)加載所有關(guān)聯(lián)的Order對(duì)象。以Customer和Order類為例,假定ORDERS表的CUSTOMER_ID外鍵允許為null,圖1列出了CUSTOMERS表和ORDERS表中的記錄。


以下Session的find()方法用于到數(shù)據(jù)庫中檢索所有的Customer對(duì)象:

List customerLists=session.find("from Customer as c");

運(yùn)行以上find()方法時(shí),Hibernate將先查詢CUSTOMERS表中所有的記錄,然后根據(jù)每條記錄的ID,到ORDERS表中查詢有參照關(guān)系的記錄,Hibernate將依次執(zhí)行以下select語句:

select * from CUSTOMERS;
select * from ORDERS where CUSTOMER_ID=1;
select * from ORDERS where CUSTOMER_ID=2;
select * from ORDERS where CUSTOMER_ID=3;
select * from ORDERS where CUSTOMER_ID=4;#p#

通過以上5條select語句,Hibernate最后加載了4個(gè)Customer對(duì)象和5個(gè)Order對(duì)象,在內(nèi)存中形成了一幅關(guān)聯(lián)的對(duì)象圖,參見圖2。


Hibernate在檢索與Customer關(guān)聯(lián)的Order對(duì)象時(shí),使用了默認(rèn)的立即檢索策略。這種檢索策略存在兩大不足:

(1) select語句的數(shù)目太多,需要頻繁的訪問數(shù)據(jù)庫,會(huì)影響檢索性能。如果需要查詢n個(gè)Customer對(duì)象,那么必須執(zhí)行n+1次select查詢語句。這就是經(jīng)典的n+1次select查詢問題。這種檢索策略沒有利用SQL的連接查詢功能,例如以上5條select語句完全可以通過以下1條select語句來完成:

select * from CUSTOMERS left outer join ORDERS
on CUSTOMERS.ID=ORDERS.CUSTOMER_ID

以上select語句使用了SQL的左外連接查詢功能,能夠在一條select語句中查詢出CUSTOMERS表的所有記錄,以及匹配的ORDERS表的記錄。

(2)在應(yīng)用邏輯只需要訪問Customer對(duì)象,而不需要訪問Order對(duì)象的場(chǎng)合,加載Order對(duì)象完全是多余的操作,這些多余的Order對(duì)象白白浪費(fèi)了許多內(nèi)存空間。
為了解決以上問題,Hibernate提供了其他兩種檢索策略:延遲檢索策略和迫切左外連接檢索策略。延遲檢索策略能避免多余加載應(yīng)用程序不需要訪問的關(guān)聯(lián)對(duì)象,迫切左外連接檢索策略則充分利用了SQL的外連接查詢功能,能夠減少select語句的數(shù)目。

 

【編輯推薦】

SQL語句中的鎖定語句

SQL中SELECT INTO和INSERT INTO SELECT語句介紹

如何解決SQL Server中傳入select語句in范圍參數(shù)

使用SQL中SELECT語句的使用條件邏輯

SQL語句中的嵌套SELECT語句

責(zé)任編輯:段燃 來源: 博客園
相關(guān)推薦

2010-08-23 09:50:20

Ruby on Rai

2023-06-13 18:27:29

數(shù)量Java定期測(cè)試

2019-05-24 08:36:33

MySQL查詢SQL

2011-05-18 10:24:55

Oracle

2010-09-03 15:27:02

SQLSELECT語句

2020-11-16 07:26:25

賠償碼農(nóng)

2010-11-11 11:37:22

SQL SELECT語

2010-09-03 14:39:15

SQLSELECT語句

2018-11-30 08:38:24

裁員互聯(lián)網(wǎng)電商

2023-03-30 09:10:06

SQLSELECTFROM

2025-04-07 07:20:35

SQL慢查詢性能

2010-09-08 15:51:53

SQL語句where

2010-09-07 16:38:36

SQL語句SELECT DIST

2010-09-03 14:47:50

SQLSELECT語句

2010-11-11 11:49:02

SQL嵌套SELECT

2021-05-26 05:22:48

SQL 數(shù)據(jù)庫SELECT

2009-02-26 08:42:31

聯(lián)想裁員賠償標(biāo)準(zhǔn)

2010-09-07 10:35:38

SQL語句

2019-10-23 08:45:34

SQL數(shù)據(jù)庫開發(fā)

2010-09-03 14:56:12

SQLSELECT語句
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 中文字幕在线不卡 | 亚洲精品456| 狠狠干网站 | 精品不卡 | 亚洲国产一区二区三区在线观看 | 久久精品16 | 亚洲网站观看 | 国产精品网址 | 国产精品美女久久久久aⅴ国产馆 | 中文字幕亚洲区一区二 | 欧美国产日韩成人 | 中文字幕日韩一区 | 久久久久久久国产精品影院 | 亚洲国产成人精品久久 | 成人伊人 | 午夜羞羞 | www.干| 性色av一区二区三区 | 国产福利在线 | 久久久一区二区 | 日韩在线不卡视频 | av网站免费 | 欧美一二区 | 国产一区影院 | 日韩精品一区二区三区在线观看 | 日韩美女爱爱 | 黄色欧美在线 | 一区二区三区四区国产精品 | 色婷婷av一区二区三区软件 | 精品一区二区三区免费毛片 | 91不卡 | 欧美日韩中文字幕在线播放 | 欧美日韩一区二区三区视频 | 国产欧美视频一区 | 亚洲一区二区三区桃乃木香奈 | 二区亚洲 | 91精品国产91久久综合桃花 | 亚洲精彩视频在线观看 | 久久亚洲一区二区三区四区 | 日韩三级视频 | 成人av片在线观看 |