亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际

17站長網

17站長網 首頁 數據庫 Mysql 查看內容

相關MYSQL DML UPDATE DELETE 中的子查詢問題

2023-3-16 14:21| 查看: 2882 |來源: 互聯網

從5.6開始MYSQL的子查詢進行了大量的優化,5.5中只有EXISTS strategy,在5.7中包含如下: IN(=ANY) --Semi-join --table pullout(最快的,子查詢條件為唯一 ...

從5.6開始MYSQL的子查詢進行了大量的優化,5.5中只有EXISTS strategy,在5.7中包含如下:

      IN(=ANY)

      --Semi-join

      --table pullout(最快的,子查詢條件為唯一鍵)

      --first match

      --semi-join materialization

      --loosescan

       --duplicateweedout

--Materialization

--EXISTS strategy(最慢的)

NOT IN( <>ALL)

--Materialization

--EXISTS strategy(最慢的)

 

 

而(not)exist卻沒有任何優化還是關聯子查詢的方式,這和ORACLE不一樣,ORACLE中in、exists

都可以使用半連接(semi)優化.所以MYSQL中盡量使用in不要用exists。not in不能使用semi-join

要小心使用,更不要用not exists,關于上面每一個含義可以參考官方手冊和mariadb手冊。

 

我們簡單的看一個列子,

 

 

使用semi-join materialization優化的

mysql> explain select * from testde1 where testde1.id in(select id from testde2);

+----+--------------+-------------+------------+------+---------------+------+---------+------+------+----------+----------------------------------------------------+

| id | select_type  | table       | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra                                              |

+----+--------------+-------------+------------+------+---------------+------+---------+------+------+----------+----------------------------------------------------+

|  1 | SIMPLE       | | NULL       | ALL  | NULL          | NULL | NULL    | NULL | NULL |   100.00 | NULL                                               |

|  1 | SIMPLE       | testde1     | NULL       | ALL  | NULL          | NULL | NULL    | NULL |   15 |    10.00 | Using where; Using join buffer (Block Nested Loop) |

|  2 | MATERIALIZED | testde2     | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    2 |   100.00 | NULL                                               |

+----+--------------+-------------+------------+------+---------------+------+---------+------+------+----------+----------------------------------------------------+

3 rows in set, 1 warning (0.00 sec)

  

禁用semi join使用Materialization優化

mysql> set optimizer_switch='semijoin=off';

Query OK, 0 rows affected (0.00 sec)

 

 

mysql> explain select * from testde1 where testde1.id in(select id from testde2);

+----+-------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

| id | select_type | table   | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra       |

+----+-------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

|  1 | PRIMARY     | testde1 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |   15 |   100.00 | Using where |

|  2 | SUBQUERY    | testde2 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    2 |   100.00 | NULL        |

+----+-------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

2 rows in set, 1 warning (0.00 sec)

 

禁用join使用Materialization

ysql> set optimizer_switch='materialization=off';

Query OK, 0 rows affected (0.00 sec)

 

 

mysql> explain select * from testde1 where testde1.id in(select id from testde2);

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

| id | select_type        | table   | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra       |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

|  1 | PRIMARY            | testde1 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |   15 |   100.00 | Using where |

|  2 | DEPENDENT SUBQUERY | testde2 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    2 |    50.00 | Using where |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

2 rows in set, 1 warning (0.00 sec)

 

 

Note (Code 1003): /* select#1 */ select `test`.`testde1`.`id` AS `id` from `test`.`testde1` where (`test`.`testde1`.`id`,(/* select#2 */ select 1 from `test`.`testde2` where ((`test`.`testde1`.`id`) = `test`.`testde2`.`id`)))

 

 

使用DEPENDENT SUBQUERY 關聯子查詢優化,這也是最慢的。這和

select * from testde1 where exists (select * from testde2 where testde1.id=testde2.id);的執行計劃完全一致,

testde1大表必須作為驅動表

mysql> explain select * from testde1 where exists (select * from testde2 where testde1.id=testde2.id);

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

| id | select_type        | table   | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra       |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

|  1 | PRIMARY            | testde1 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |   15 |   100.00 | Using where |

|  2 | DEPENDENT SUBQUERY | testde2 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    2 |    50.00 | Using where |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

2 rows in set, 2 warnings (0.00 sec)

 

實際就是下面的執行計劃:

 

 

mysql> explain delete from testde1 where id in (select id from testde2);

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

| id | select_type        | table   | partitions | type | possible_keys | key  | key_len | ref  | rows | filtered | Extra       |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

|  1 | DELETE             | testde1 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |   15 |   100.00 | Using where |

|  2 | DEPENDENT SUBQUERY | testde2 | NULL       | ALL  | NULL          | NULL | NULL    | NULL |    2 |    50.00 | Using where |

+----+--------------------+---------+------------+------+---------------+------+---------+------+------+----------+-------------+

2 rows in set (0.00 sec)

 

這里我們看到小表testde2做了驅動表。

最后來說明一下這個報錯:

mysql> delete from testde1 where id in(select testde1.id from testde1,testde2 where testde1.id=testde2.id );

ERROR 1093 (HY000): You can't specify target table 'testde1' for update in FROM clause

我們先不管他有沒有意義,這個報錯再手冊上叫做ER_UPDATE_TABLE_USED,我們首先來分析一下這個報錯

這樣的delete會進行exists展開那么testde1既是修改條件的來源也是修改的對象,這樣是不允許的。那么如何修改呢?

實際上就需要select testde1.id from testde1,testde2 where testde1.id=testde2.id 的結果保存在一個臨時表中,

不要exists展開,手冊中給出的方法是

方法一、建立一個algorithm=temptable 的視圖

方法二、建立一個普通視圖同時修改SET optimizer_switch = 'derived_merge=off';

 

 

其目的都在于不展開選取第二種方式測試:

mysql> create view myt1

    -> as

    -> select testde1.id from testde1,testde2 where testde1.id=testde2.id;

Query OK, 0 rows affected (0.02 sec)

  

mysql> show status like '%tmp%';

+-------------------------+-------+

| Variable_name           | Value |

+-------------------------+-------+

| Created_tmp_disk_tables | 0     |

| Created_tmp_files       | 0     |

| Created_tmp_tables      | 2    |

+-------------------------+-------+

3 rows in set (0.01 sec)

 

看看執行計劃:

mysql> explain delete from testde1 where id in (select * from myt1);

+----+--------------------+------------+------------+----------------+---------------+-------------+---------+------+------+----------+----------------------------------------------------+

| id | select_type        | table      | partitions | type           | possible_keys | key         | key_len | ref  | rows | filtered | Extra                                              |

+----+--------------------+------------+------------+----------------+---------------+-------------+---------+------+------+----------+----------------------------------------------------+

|  1 | DELETE             | testde1    | NULL       | ALL            | NULL          | NULL        | NULL    | NULL |   13 |   100.00 | Using where                                        |

|  2 | DEPENDENT SUBQUERY | | NULL       | index_subquery |   | | 5       | func |    2 |   100.00 | Using index                                        |

|  3 | DERIVED            | testde2    | NULL       | ALL            | NULL          | NULL        | NULL    | NULL |    2 |   100.00 | NULL                                               |

|  3 | DERIVED            | testde1    | NULL       | ALL            | NULL          | NULL        | NULL    | NULL |   13 |    10.00 | Using where; Using join buffer (Block Nested Loop) |

+----+--------------------+------------+------------+----------------+---------------+-------------+---------+------+------+----------+----------------------------------------------------+

4 rows in set (0.00 sec)

  

先使用hash join將TESTDE2 和TESTDE1  建立為一個視圖VW_NSO_1,然后使用了HASH JOIN SEMI的優化方式,明顯用了到半連接優化

這也是為什么ORACLE比現在的MYSQL還是更加強勁的一個小例子,雖然都是作為一個整體,但是MYSQL已經用不到SEMI優化方式了,ORACLE

依然可以,但是可以預見不久的將來MYSQL肯定支持的。

本文最后更新于 2023-3-16 14:21,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:17tui@17tui.com
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

    熱門排行

      最近更新

        返回頂部
        亚洲国产精品人久久,亚洲va国产日韩欧美精品色婷婷,久久久久88色偷偷,免费人成黄页在线观看国际
        国产精品三级久久久久三级| 国产日韩精品视频一区| 99久久精品免费看| 国产成人精品一区二区三区四区| 亚州成人在线电影| 亚洲黄色小视频| 亚洲人成网站影音先锋播放| 国产女同互慰高潮91漫画| 国产午夜精品一区二区三区视频| 精品久久人人做人人爽| 国产网站一区二区三区| 欧美激情一区三区| 亚洲欧美二区三区| 亚洲午夜国产一区99re久久| 天天色天天操综合| 久久精品国产77777蜜臀| 狠狠色丁香婷综合久久| 国产91露脸合集magnet| 一本色道亚洲精品aⅴ| 欧美在线免费观看视频| 日韩一区二区影院| 亚洲欧美在线另类| 日韩国产欧美在线视频| 国产丶欧美丶日本不卡视频| 91久久精品一区二区二区| 91精品欧美一区二区三区综合在| 精品美女一区二区三区| 亚洲人被黑人高潮完整版| 婷婷丁香久久五月婷婷| 国产成人在线观看| 欧美美女视频在线观看| 国产人久久人人人人爽| 亚洲成人综合视频| k8久久久一区二区三区| 欧美日韩国产一区二区三区地区| 久久久综合九色合综国产精品| 亚洲男女毛片无遮挡| 国产尤物一区二区在线| 欧美日韩精品三区| 国产精品卡一卡二| 紧缚奴在线一区二区三区| 欧美综合一区二区| 国产精品久久毛片a| 激情综合一区二区三区| 欧美人xxxx| 亚洲综合999| 色诱视频网站一区| 国产精品久久久久三级| 韩国欧美国产1区| 日韩丝袜美女视频| 日韩电影一区二区三区| 欧美色精品天天在线观看视频| 国产精品国模大尺度视频| 国产老妇另类xxxxx| 精品久久久久香蕉网| 爽好多水快深点欧美视频| 色天使色偷偷av一区二区| 亚洲人成网站色在线观看| 福利一区二区在线| 日本一区二区三区免费乱视频 | 中文字幕精品一区二区精品绿巨人| 日日摸夜夜添夜夜添国产精品| 欧美在线播放高清精品| 亚洲午夜视频在线| 欧美日韩一区精品| 日韩黄色免费网站| 精品欧美乱码久久久久久| 精品一区二区久久久| 国产亚洲欧美日韩俺去了| 精品一区二区三区蜜桃| 2022国产精品视频| 成人午夜av电影| 亚洲精品日韩综合观看成人91| 欧美性xxxxx极品少妇| 日韩电影免费在线观看网站| 久久一区二区三区国产精品| 国产盗摄女厕一区二区三区| 国产精品日产欧美久久久久| 91福利视频在线| 毛片av一区二区三区| 国产欧美一区二区精品秋霞影院| 99久久久精品| 精品一区二区av| 亚洲综合999| 久久久九九九九| 欧美吞精做爰啪啪高潮| 日韩毛片精品高清免费| 欧美一区二区在线观看| 粉嫩在线一区二区三区视频| 亚洲精品福利视频网站| 精品国产91洋老外米糕| 在线看日韩精品电影| 国产精品资源在线看| 亚洲成人在线观看视频| 欧美极品xxx| 欧美一区二区三区喷汁尤物| 97精品久久久午夜一区二区三区| 婷婷久久综合九色综合伊人色| 国产清纯在线一区二区www| 欧美日韩午夜在线| 99精品视频一区| 国产精品亚洲一区二区三区妖精| 亚洲成人福利片| 亚洲欧美日韩成人高清在线一区| 精品sm在线观看| 欧美一区二区三区视频免费播放 | 欧美色涩在线第一页| 国产在线播放一区二区三区| 日韩国产高清影视| 午夜精品福利在线| 亚洲综合视频网| 亚洲欧美日韩国产综合在线| 中文字幕乱码久久午夜不卡| 日韩精品专区在线影院重磅| 欧美人与z0zoxxxx视频| 91高清视频在线| 99久久99久久精品国产片果冻| 国产精品一区免费视频| 麻豆精品一二三| 乱一区二区av| 国内一区二区视频| 国产又黄又大久久| 国产a精品视频| 粉嫩av一区二区三区| 成人一级片网址| av电影在线观看完整版一区二区| 粉嫩aⅴ一区二区三区四区五区| 大胆欧美人体老妇| 色综合视频一区二区三区高清| 91在线一区二区| 欧美在线视频全部完| 91精选在线观看| 精品福利一区二区三区| 国产亚洲一区二区三区四区| 国产欧美日韩在线| 亚洲人成精品久久久久久 | 亚洲日本在线a| 亚洲小说欧美激情另类| 蜜桃视频一区二区三区| 国产一二三精品| 色婷婷综合五月| 欧美男生操女生| 久久久高清一区二区三区| 中文字幕亚洲一区二区av在线| 一区二区三区四区国产精品| 日日摸夜夜添夜夜添亚洲女人| 国产精品一区二区久激情瑜伽| 99久久婷婷国产精品综合| 欧美日韩国产小视频| 精品国产乱码久久| 亚洲最新视频在线观看| 国内精品国产三级国产a久久| 91视频精品在这里| 精品国产乱码久久久久久图片| 亚洲精品免费在线播放| 精品一区二区三区免费视频| 色成人在线视频| 久久午夜免费电影| 亚洲mv在线观看| 成人18视频在线播放| 日韩欧美自拍偷拍| 亚洲午夜私人影院| 99精品国产一区二区三区不卡| 日韩一区二区精品葵司在线| **性色生活片久久毛片| 精品午夜一区二区三区在线观看| 欧洲一区在线电影| 亚洲欧美综合另类在线卡通| 国产成人精品亚洲777人妖| 欧美一区二区福利在线| 亚洲在线一区二区三区| caoporm超碰国产精品| 国产日韩欧美一区二区三区综合| 日韩高清国产一区在线| 欧美人妖巨大在线| 日精品一区二区三区| 欧洲精品一区二区三区在线观看| 国产精品电影一区二区三区| 丁香天五香天堂综合| 久久免费的精品国产v∧| 奇米色一区二区| 4438x亚洲最大成人网| 亚洲影视资源网| 欧美色综合影院| 亚洲成人在线网站| 69久久99精品久久久久婷婷 | 亚洲精品久久嫩草网站秘色| 成人午夜在线播放| 国产精品国产自产拍高清av王其 | 国产一区二区三区观看| 精品国产91乱码一区二区三区| 日韩国产一二三区| 精品成a人在线观看| 国产激情精品久久久第一区二区 | 91美女片黄在线观看| 亚洲乱码国产乱码精品精小说| 日本电影亚洲天堂一区| 日韩黄色片在线观看| 久久精品人人做人人爽人人| 成人av在线一区二区|