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

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

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

優(yōu)化DBLE獨(dú)立子查詢教程

jf_78858299 ? 來(lái)源:基礎(chǔ)技術(shù)研究 ? 作者:林海 ? 2023-03-29 13:50 ? 次閱讀

01問題

前期開發(fā)反饋在使用獨(dú)立子查詢時(shí),不論子查詢中結(jié)果集有幾個(gè),語(yǔ)句都會(huì)卡死遲遲得不到返回結(jié)果。但是如果去掉子查詢,直接賦值查詢很快得到返回結(jié)果。聽到這個(gè)情況第一反應(yīng)很可能DBLE在獨(dú)立子查詢上沒有做相關(guān)優(yōu)化,真的是這樣么?下面我們將問題復(fù)現(xiàn)以及優(yōu)化方式進(jìn)行展示。

02 演示及優(yōu)化

環(huán)境檢查

DBLE版本:2.19.11.5

 MySQL版本:5.7.28

 涉及分片表:src_biz_filelist     

 分片鍵:batch_no

 涉及垂直表:src_image_txn_jnl

 分片拆分規(guī)則:stringhash

 節(jié)點(diǎn)數(shù)量:4

2.1 原始語(yǔ)句及執(zhí)行計(jì)劃

獨(dú)立子查詢語(yǔ)句如下:

select caption,batch_no,image_no from src_biz_filelist where batch_no in (SELECT imageid FROM src_image_txn_jnl WHERE  front_seq_num = '001780568097' and txn_dt = '2029-08-20')

執(zhí)行計(jì)劃如下:

mysql> explain select caption,batch_no,image_no from src_biz_filelist where batch_no in (SELECT imageid FROM src_image_txn_jnl WHERE  front_seq_num = '001780568097' and txn_dt = '2029-08-20');
+-------------------+-----------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| DATA_NODE         | TYPE            | SQL/REF                                                                                                                                                                                                                                                                                                                                                                                              |
+-------------------+-----------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| dn1_0             | BASE SQL        | select `src_biz_filelist`.`ysyid`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no`,`src_biz_filelist`.`caption`,`src_biz_filelist`.`create_time`,`src_biz_filelist`.`update_time`,`src_biz_filelist`.`img_seql`,`src_biz_filelist`.`data_date` from  `src_biz_filelist` ORDER BY `src_biz_filelist`.`batch_no` ASC                                                                        |
| dn2_0             | BASE SQL        | select `src_biz_filelist`.`ysyid`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no`,`src_biz_filelist`.`caption`,`src_biz_filelist`.`create_time`,`src_biz_filelist`.`update_time`,`src_biz_filelist`.`img_seql`,`src_biz_filelist`.`data_date` from  `src_biz_filelist` ORDER BY `src_biz_filelist`.`batch_no` ASC                                                                        |
| dn3_0             | BASE SQL        | select `src_biz_filelist`.`ysyid`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no`,`src_biz_filelist`.`caption`,`src_biz_filelist`.`create_time`,`src_biz_filelist`.`update_time`,`src_biz_filelist`.`img_seql`,`src_biz_filelist`.`data_date` from  `src_biz_filelist` ORDER BY `src_biz_filelist`.`batch_no` ASC                                                                        |
| dn4_0             | BASE SQL        | select `src_biz_filelist`.`ysyid`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no`,`src_biz_filelist`.`caption`,`src_biz_filelist`.`create_time`,`src_biz_filelist`.`update_time`,`src_biz_filelist`.`img_seql`,`src_biz_filelist`.`data_date` from  `src_biz_filelist` ORDER BY `src_biz_filelist`.`batch_no` ASC                                                                        |
| merge_and_order_1 | MERGE_AND_ORDER | dn1_0; dn2_0; dn3_0; dn4_0                                                                                                                                                                                                                                                                                                                                                                           |
| shuffle_field_1   | SHUFFLE_FIELD   | merge_and_order_1                                                                                                                                                                                                                                                                                                                                                                                    |
| dn1_1             | BASE SQL        | select `autoalias_src_image_txn_jnl`.`autoalias_scalar` from (select  distinct `src_image_txn_jnl`.`imageid` as `autoalias_scalar` from  `src_image_txn_jnl` where (`src_image_txn_jnl`.`front_seq_num` = '001780568097') AND (`src_image_txn_jnl`.`txn_dt` = '2029-08-20') order by autoalias_scalar ASC) autoalias_src_image_txn_jnl order by `autoalias_src_image_txn_jnl`.`autoalias_scalar` ASC |
| merge_1           | MERGE           | dn1_1                                                                                                                                                                                                                                                                                                                                                                                                |
| join_1            | JOIN            | shuffle_field_1; merge_1                                                                                                                                                                                                                                                                                                                                                                             |
| shuffle_field_2   | SHUFFLE_FIELD   | join_1                                                                                                                                                                                                                                                                                                                                                                                               |
+-------------------+-----------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
10 rows in set (0.00 sec)

**執(zhí)行計(jì)劃可見,DBLE對(duì)語(yǔ)句進(jìn)行了拆分。首先分別在4個(gè)數(shù)據(jù)節(jié)點(diǎn)全表掃描分片表src_biz_filelist,將各自返回的結(jié)果集在DBLE層合并排序。然后將子查詢結(jié)果去重排序后返回。最后在DBLE層進(jìn)行匹配操作。當(dāng)分片表數(shù)據(jù)量較大時(shí),全部提取數(shù)據(jù)動(dòng)作,即使不與子查詢中結(jié)果集匹配,效率也不會(huì)很好。

**

按照開發(fā)描述改寫子查詢語(yǔ)句賦予具體值,進(jìn)行查看:

mysql> explain select caption,batch_no,image_no from src_biz_filelist where batch_no in ('0250002403989000IMMEDA200630095447WV','1650002432532000IMMEDA200630095233WS');
+-----------+----------+------------------------------------------------------------------------------------------------------------------------------------------------------+
| DATA_NODE | TYPE     | SQL/REF                                                                                                                                              |
+-----------+----------+------------------------------------------------------------------------------------------------------------------------------------------------------+
| dn4       | BASE SQL | select caption,batch_no,image_no from src_biz_filelist where batch_no in ('0250002403989000IMMEDA200630095447WV','1650002432532000IMMEDA200630095233WS') |
+-----------+----------+------------------------------------------------------------------------------------------------------------------------------------------------------+
1 rows in set (0.00 sec)

因?yàn)榉制韘rc_biz_filelist的分片鍵為batch_no,語(yǔ)句直接下壓到了數(shù)據(jù)所在的dn4節(jié)點(diǎn)。驗(yàn)證了開發(fā)描述的在使用獨(dú)立子查詢時(shí),不論子查詢中結(jié)果集有幾個(gè),語(yǔ)句都會(huì)卡死遲遲得不到返回結(jié)果。如果去掉子查詢賦予具體值,很快得到返回結(jié)果。程序進(jìn)行語(yǔ)句拆分傳入具體值查詢,也是我們的優(yōu)化方法之一。那是不是DBLE在獨(dú)立子查詢上真的沒有做相關(guān)優(yōu)化呢?我們繼續(xù)操作。

**2.2 **獨(dú)立標(biāo)量子查詢語(yǔ)句及執(zhí)行計(jì)劃

如果明確子查詢結(jié)果單個(gè)值情況下,可以改寫使用獨(dú)立標(biāo)量子查詢,執(zhí)行計(jì)劃如下:

mysql> explain select caption,batch_no,image_no from src_biz_filelist where batch_no = (SELECT imageid FROM src_image_txn_jnl WHERE  front_seq_num = '001780568097' and txn_dt = '2029-08-20');
+--------------------+-----------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| DATA_NODE          | TYPE                  | SQL/REF                                                                                                                                                                                                       |
+--------------------+-----------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| dn1_0              | BASE SQL              | select `src_image_txn_jnl`.`imageid` as `autoalias_scalar` from  `src_image_txn_jnl` where (`src_image_txn_jnl`.`front_seq_num` = '001780568097') AND (`src_image_txn_jnl`.`txn_dt` = '2029-08-20') limit 0,2 |
| merge_1            | MERGE                 | dn1_0                                                                                                                                                                                                         |
| scalar_sub_query_1 | SCALAR_SUB_QUERY      | merge_1                                                                                                                                                                                                       |
| dn1_1              | BASE SQL(May No Need) | scalar_sub_query_1; select `src_biz_filelist`.`caption`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no` from  `src_biz_filelist` where `src_biz_filelist`.`batch_no` = '{NEED_TO_REPLACE}'        |
| dn2_0              | BASE SQL(May No Need) | scalar_sub_query_1; select `src_biz_filelist`.`caption`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no` from  `src_biz_filelist` where `src_biz_filelist`.`batch_no` = '{NEED_TO_REPLACE}'        |
| dn3_0              | BASE SQL(May No Need) | scalar_sub_query_1; select `src_biz_filelist`.`caption`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no` from  `src_biz_filelist` where `src_biz_filelist`.`batch_no` = '{NEED_TO_REPLACE}'        |
| dn4_0              | BASE SQL(May No Need) | scalar_sub_query_1; select `src_biz_filelist`.`caption`,`src_biz_filelist`.`batch_no`,`src_biz_filelist`.`image_no` from  `src_biz_filelist` where `src_biz_filelist`.`batch_no` = '{NEED_TO_REPLACE}'        |
| merge_2            | MERGE                 | dn1_1; dn2_0; dn3_0; dn4_0                                                                                                                                                                                    |
| shuffle_field_1    | SHUFFLE_FIELD         | merge_2                                                                                                                                                                                                       |
+--------------------+-----------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
9 rows in set (0.00 sec)

執(zhí)行計(jì)劃可見:dn1_0部分先將子查詢結(jié)果返回,出現(xiàn)了SCALAR_SUB_QUERY標(biāo)量子查詢的標(biāo)識(shí),被引用到外部查詢中,語(yǔ)句直接下壓到了全部數(shù)據(jù)節(jié)點(diǎn)。這種情況下依據(jù)分片鍵進(jìn)行等值查詢,效率是OK的。

****03 解決

通過查看原始語(yǔ)句在DBLE的執(zhí)行計(jì)劃,下壓到MySQL時(shí),由于DBLE對(duì)語(yǔ)句進(jìn)行了重寫,并沒有使用到MySQL優(yōu)化器改寫語(yǔ)句為semi join方式。在MySQL中需要使用子查詢完成的任務(wù),很多時(shí)候可以使用連接方式來(lái)實(shí)現(xiàn),那么我們?cè)谏蠈泳椭貙憺閖oin語(yǔ)句實(shí)驗(yàn)一下。

查看DBLE文檔server.xml 系統(tǒng)參數(shù)配置部分有一個(gè)useJoinStrategy參數(shù),該參數(shù)作用是開啟之后會(huì)嘗試判斷join兩邊的where來(lái)重新調(diào)整查詢SQL下發(fā)的順序,默認(rèn)關(guān)閉。添加true至server.xml的標(biāo)簽中,并重啟DBLE。

查看改寫之后語(yǔ)句執(zhí)行計(jì)劃:

mysql> explain select t1.caption,t1.batch_no,t1.image_no from src_biz_filelist t1 inner join src_image_txn_jnl t2 on t1.batch_no=t2.imageid  WHERE  t2.front_seq_num = '001780568097' and t2.txn_dt = '2029-08-20';
+-------------------+-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| DATA_NODE         | TYPE                  | SQL/REF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
+-------------------+-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
| dn1_0             | BASE SQL              | select `t2`.`id`,`t2`.`evt_id`,`t2`.`front_seq_num`,`t2`.`org_id`,`t2`.`teller_id`,`t2`.`txn_dt`,`t2`.`txn_tm`,`t2`.`txn_type_cd`,`t2`.`txn_cd`,`t2`.`sub_seq_num`,`t2`.`bcs_seq_num`,`t2`.`user_ccy_cd`,`t2`.`acct_num`,`t2`.`acct_ccy_cd`,`t2`.`acct_amt`,`t2`.`txn_ccy_cd`,`t2`.`txn_amt`,`t2`.`exch_rate`,`t2`.`resp_num`,`t2`.`proc_info`,`t2`.`auth_teller_id`,`t2`.`terminal_num`,`t2`.`cntrpty_acct_num`,`t2`.`cntrpty_acct_name`,`t2`.`vchr_type_encode`,`t2`.`vchr_num`,`t2`.`vchr_dt`,`t2`.`chk_teller_id`,`t2`.`vchr_main_file_desc`,`t2`.`vchr_accessory_desc`,`t2`.`biz_status_cd`,`t2`.`fin_txn_ind`,`t2`.`txn_complt_dt`,`t2`.`ident_chk_chker_id`,`t2`.`ident_chk_result_cd`,`t2`.`veri_seal_chker_id`,`t2`.`veri_seal_result_cd`,`t2`.`tel_che_chker_id`,`t2`.`tel_che_result_cd`,`t2`.`tel_che_comment`,`t2`.`pay_acct_doubt_type_cd`,`t2`.`rcv_acct_doubt_type_cd`,`t2`.`job_center`,`t2`.`imageid`,`t2`.`pay_name`,`t2`.`txn_desc`,`t2`.`origin_txn_seq_num`,`t2`.`txn_start_tm`,`t2`.`txn_memo`,`t2`.`bcs_or_back_txn_num`,`t2`.`bea_intrfc_num`,`t2`.`txn_auth_teller`,`t2`.`send_back_or_back_err_info`,`t2`.`data_date` from  `src_image_txn_jnl` `t2` where (`t2`.`front_seq_num` = '001780568097') AND (`t2`.`txn_dt` = '2029-08-20') order by `t2`.`imageid` ASC |
| merge_1           | MERGE                 | dn1_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| nest_loop_1       | NEST_LOOP             | merge_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| dn1_1             | BASE SQL(May No Need) | nest_loop_1's RESULTS; select `t1`.`ysyid`,`t1`.`batch_no`,`t1`.`image_no`,`t1`.`caption`,`t1`.`create_time`,`t1`.`update_time`,`t1`.`img_seql`,`t1`.`data_date` from  `src_biz_filelist` `t1` where t1.batch_no IN ('{NEED_TO_REPLACE}') ORDER BY `t1`.`batch_no` ASC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| dn2_0             | BASE SQL(May No Need) | nest_loop_1's RESULTS; select `t1`.`ysyid`,`t1`.`batch_no`,`t1`.`image_no`,`t1`.`caption`,`t1`.`create_time`,`t1`.`update_time`,`t1`.`img_seql`,`t1`.`data_date` from  `src_biz_filelist` `t1` where t1.batch_no IN ('{NEED_TO_REPLACE}') ORDER BY `t1`.`batch_no` ASC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| dn3_0             | BASE SQL(May No Need) | nest_loop_1's RESULTS; select `t1`.`ysyid`,`t1`.`batch_no`,`t1`.`image_no`,`t1`.`caption`,`t1`.`create_time`,`t1`.`update_time`,`t1`.`img_seql`,`t1`.`data_date` from  `src_biz_filelist` `t1` where t1.batch_no IN ('{NEED_TO_REPLACE}') ORDER BY `t1`.`batch_no` ASC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| dn4_0             | BASE SQL(May No Need) | nest_loop_1's RESULTS; select `t1`.`ysyid`,`t1`.`batch_no`,`t1`.`image_no`,`t1`.`caption`,`t1`.`create_time`,`t1`.`update_time`,`t1`.`img_seql`,`t1`.`data_date` from  `src_biz_filelist` `t1` where t1.batch_no IN ('{NEED_TO_REPLACE}') ORDER BY `t1`.`batch_no` ASC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| merge_and_order_1 | MERGE_AND_ORDER       | dn1_1; dn2_0; dn3_0; dn4_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| shuffle_field_1   | SHUFFLE_FIELD         | merge_and_order_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| join_1            | JOIN                  | nest_loop_1; shuffle_field_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| shuffle_field_2   | SHUFFLE_FIELD         | join_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
+-------------------+-----------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
11 rows in set (0.00 sec)

執(zhí)行計(jì)劃可見:dn1_0部分先將子查詢結(jié)果返回,出現(xiàn)了NEST_LOOP嵌套循環(huán)標(biāo)識(shí),嵌套循環(huán)的結(jié)果集被引用到外部查詢中,語(yǔ)句直接下壓到了全部數(shù)據(jù)節(jié)點(diǎn)。

開啟MySQL general_log 日志查看語(yǔ)句實(shí)際在MySQL層運(yùn)行情況如下:

2021-05-12T08:58:09.324017+08:00         1080 Query     select `t2`.`id`,`t2`.`evt_id`,`t2`.`front_seq_num`,`t2`.`org_id`,`t2`.`teller_id`,`t2`.`txn_dt`,`t2`.`txn_tm`,`t2`.`txn_type_cd`,`t2`.`txn_cd`,`t2`.`sub_seq_num`,`t2`.`bcs_seq_num`,`t2`.`user_ccy_cd`,`t2`.`acct_num`,`t2`.`acct_ccy_cd`,`t2`.`acct_amt`,`t2`.`txn_ccy_cd`,`t2`.`txn_amt`,`t2`.`exch_rate`,`t2`.`resp_num`,`t2`.`proc_info`,`t2`.`auth_teller_id`,`t2`.`terminal_num`,`t2`.`cntrpty_acct_num`,`t2`.`cntrpty_acct_name`,`t2`.`vchr_type_encode`,`t2`.`vchr_num`,`t2`.`vchr_dt`,`t2`.`chk_teller_id`,`t2`.`vchr_main_file_desc`,`t2`.`vchr_accessory_desc`,`t2`.`biz_status_cd`,`t2`.`fin_txn_ind`,`t2`.`txn_complt_dt`,`t2`.`ident_chk_chker_id`,`t2`.`ident_chk_result_cd`,`t2`.`veri_seal_chker_id`,`t2`.`veri_seal_result_cd`,`t2`.`tel_che_chker_id`,`t2`.`tel_che_result_cd`,`t2`.`tel_che_comment`,`t2`.`pay_acct_doubt_type_cd`,`t2`.`rcv_acct_doubt_type_cd`,`t2`.`job_center`,`t2`.`imageid`,`t2`.`pay_name`,`t2`.`txn_desc`,`t2`.`origin_txn_seq_num`,`t2`.`txn_start_tm`,`t2`.`txn_memo`,`t2`.`bcs_or_back_txn_num`,`t2`.`bea_intrfc_num`,`t2`.`txn_auth_teller`,`t2`.`send_back_or_back_err_info`,`t2`.`data_date` from  `src_image_txn_jnl` `t2` where (`t2`.`front_seq_num` = '001780568097') AND (`t2`.`txn_dt` = '2029-08-20') order by `t2`.`imageid` ASC 
2021-05-12T08:58:09.326400+08:00         1091 Query     select `t1`.`ysyid`,`t1`.`batch_no`,`t1`.`image_no`,`t1`.`caption`,`t1`.`create_time`,`t1`.`update_time`,`t1`.`img_seql`,`t1`.`data_date` from  `src_biz_filelist` `t1` where t1.batch_no IN ('0250002403989000IMMEDA200630095447WV', '0250002401013000IMMEDA200914092919JX') ORDER BY `t1`.`batch_no` ASC

語(yǔ)句執(zhí)行順序變化,獨(dú)立子查詢被賦予了具體值,并按分片鍵進(jìn)行數(shù)據(jù)路由的特性,下發(fā)到指定分片節(jié)點(diǎn)進(jìn)行查詢。

需要注意的是關(guān)于nestLoop還有兩個(gè)參數(shù)nestLoopConnSize /nestLoopRowsSize 若臨時(shí)表行數(shù)大于這兩個(gè)值乘積,DBLE則會(huì)報(bào)告一個(gè)后端連接錯(cuò)誤。

綜上優(yōu)化方式有以下幾種:

1、程序進(jìn)行語(yǔ)句拆分傳入具體值進(jìn)行查詢。

2、如果明確子查詢結(jié)果單個(gè)值情況下,可以改寫使用獨(dú)立標(biāo)量子查詢。

3、添加 true 參數(shù),并改寫為連接查詢。

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

    關(guān)注

    0

    文章

    357

    瀏覽量

    40734
  • 數(shù)據(jù)庫(kù)
    +關(guān)注

    關(guān)注

    7

    文章

    3712

    瀏覽量

    64023
  • MySQL
    +關(guān)注

    關(guān)注

    1

    文章

    789

    瀏覽量

    26283
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    高級(jí)查詢

    高級(jí)查詢(相關(guān)子查詢)
    發(fā)表于 05-23 16:15

    多表查詢查詢

    多表查詢查詢
    發(fā)表于 03-06 16:14

    mysql的查詢優(yōu)化

    mysql查詢優(yōu)化
    發(fā)表于 03-12 11:06

    MySQL優(yōu)化查詢性能優(yōu)化查詢優(yōu)化器的局限性與提示

    MySQL優(yōu)化三:查詢性能優(yōu)化查詢優(yōu)化器的局限性與提示
    發(fā)表于 06-02 06:34

    基于關(guān)系代數(shù)樹的查詢優(yōu)化方法實(shí)例分析

    提出了基于關(guān)系代數(shù)樹結(jié)構(gòu)的SQL查詢優(yōu)化策略。利用改進(jìn)查詢計(jì)劃的代數(shù)定律,分析基于關(guān)系代數(shù)樹的關(guān)系代數(shù)式查詢優(yōu)化方法、研究關(guān)系代數(shù)表達(dá)式與S
    發(fā)表于 05-07 10:11 ?21次下載
    基于關(guān)系代數(shù)樹的<b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>方法實(shí)例分析

    MySQL 教程—查詢

    查詢:sub query,查詢是在某個(gè)查詢結(jié)果之上進(jìn)行的,一條select語(yǔ)句內(nèi)部包含了另外一條select語(yǔ)句。
    發(fā)表于 09-11 12:44 ?5次下載
    MySQL 教程—<b class='flag-5'>子</b><b class='flag-5'>查詢</b>

    MySQL 教程—查詢(下)

    查詢:sub query,查詢是在某個(gè)查詢結(jié)果之上進(jìn)行的,一條select語(yǔ)句內(nèi)部包含了另外一條select語(yǔ)句。 行
    發(fā)表于 09-11 12:54 ?3次下載
    MySQL 教程—<b class='flag-5'>子</b><b class='flag-5'>查詢</b>(下)

    基于共享執(zhí)行策略的間隔查詢優(yōu)化

    間隔查詢作為重要的查詢類型,廣泛應(yīng)用在社交網(wǎng)絡(luò)、信息檢索和數(shù)據(jù)庫(kù)領(lǐng)域.為了支持高效的間隔查詢,涌現(xiàn)出多種優(yōu)化技術(shù).盡管已有方法能夠快速響應(yīng)單個(gè)間隔
    發(fā)表于 01-05 17:09 ?0次下載
    基于共享執(zhí)行策略的間隔<b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>

    基于Greenplum數(shù)據(jù)庫(kù)的查詢優(yōu)化

    針對(duì)分布式數(shù)據(jù)庫(kù)查詢效率隨著數(shù)據(jù)規(guī)模的增大而降低的問題,以Greenplum分布式數(shù)據(jù)庫(kù)為研究對(duì)象,從優(yōu)化查詢路徑的角度提出一個(gè)基于代價(jià)的最優(yōu)查詢計(jì)劃生成方法。首先,該方法設(shè)計(jì)一種有效
    發(fā)表于 03-29 17:46 ?0次下載

    SQL優(yōu)化器原理 - 查詢優(yōu)化器綜述

    摘要:?本文主要是對(duì)數(shù)據(jù)庫(kù)查詢優(yōu)化器的一個(gè)綜述,包括查詢優(yōu)化器分類、查詢優(yōu)化器執(zhí)行過程和CBO框
    發(fā)表于 07-24 17:38 ?284次閱讀
    SQL<b class='flag-5'>優(yōu)化</b>器原理 - <b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>器綜述

    數(shù)據(jù)庫(kù)如何進(jìn)行修改語(yǔ)句和其查詢的運(yùn)用?

    修改語(yǔ)句及其查詢的運(yùn)用插入、更新和刪除語(yǔ)句中都可以使用查詢把一個(gè)查詢的結(jié)果插入到一個(gè)數(shù)據(jù)表
    發(fā)表于 09-26 15:15 ?0次下載
    數(shù)據(jù)庫(kù)如何進(jìn)行修改語(yǔ)句和其<b class='flag-5'>子</b><b class='flag-5'>查詢</b>的運(yùn)用?

    數(shù)據(jù)庫(kù)系統(tǒng)概論之如何進(jìn)行關(guān)系查詢處理和查詢優(yōu)化

    本文檔的主要內(nèi)容詳細(xì)介紹的是數(shù)據(jù)庫(kù)系統(tǒng)概論之如何進(jìn)行關(guān)系查詢處理和查詢優(yōu)化主要內(nèi)容包括了:1、關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)的查詢處理 2、關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)的查詢
    發(fā)表于 11-15 15:12 ?11次下載
    數(shù)據(jù)庫(kù)系統(tǒng)概論之如何進(jìn)行關(guān)系<b class='flag-5'>查詢</b>處理和<b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>

    SQL查詢優(yōu)化是怎么回事

    查詢 (Subquery)的優(yōu)化一直以來(lái)都是 SQL 查詢優(yōu)化中的難點(diǎn)之一。 關(guān)聯(lián)
    的頭像 發(fā)表于 02-01 13:55 ?1955次閱讀
    SQL<b class='flag-5'>子</b><b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>是怎么回事

    一文終結(jié)SQL查詢優(yōu)化

    查詢(Subquery)的優(yōu)化一直以來(lái)都是 SQL 查詢優(yōu)化中的難點(diǎn)之一。關(guān)聯(lián)
    的頭像 發(fā)表于 04-28 14:19 ?632次閱讀
    一文終結(jié)SQL<b class='flag-5'>子</b><b class='flag-5'>查詢</b><b class='flag-5'>優(yōu)化</b>

    SQL改寫消除相關(guān)子查詢實(shí)踐

    GaussDB (DWS) 根據(jù)查詢在 SQL 語(yǔ)句中的位置把子查詢分成了查詢、鏈接兩種形
    的頭像 發(fā)表于 12-27 09:51 ?351次閱讀