亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

Mysql數據庫性能優化之子查詢

2024-07-24 13:11:50
字體:
來源:轉載
供稿:網友

記得在做項目的時候, 聽到過一句話, 盡量不要使用子查詢, 那么這一篇就來看一下, 這句話是否是正確的.

那在這之前, 需要介紹一些概念性東西和mysql/15937.html">mysql對語句的大致處理.

當Mysql Server的連接線程接收到Client發送過來的SQL請求后, 會經過一系列的分解Parse, 進行相應的分析, 然后Mysql會通過查詢優化器模塊, 根據該Sql所涉及到的數據表的相關統計信息進行計算分析. 然后在得出一個Mysql自認為最合理最優化的數據訪問方式, 也就是我們常說的"執行計劃", 然后根據所得到的執行計劃通過調用存儲引擎接口來獲取相應數據. 再對存儲引擎返回的數據進行相關的處理, 并一Client端所要求的格式作為結果集, 返回給Client.

注 : 這里所說的統計數據, 是我們通過 Analyze table命令通知Mysql對表的相關數據作分析之后, 所獲取到的一些數據統計量. 這些數據對Mysql優化器而言是非常重要的, 優化器所生成的執行計劃的好壞, 主要是由這些統計數據所決定的.

1. 建表

create table User(  Id int not null PRIMARY key auto_increment ,  NickName varchar(50) comment '用戶昵稱',  Sex int comment '性別',  Sign varchar(50) comment '用戶簽名',  Birthday datetime comment '用戶生日',  CreateTime datetime comment '創建時間') default charset=utf8 comment '用戶表';create table UserGroup(  Id int not null PRIMARY key auto_increment ,  UserId int not null comment 'user Id',  GroupId int not null comment '用戶組Id',  CreateTime datetime comment '創建時間',  -- key index_groupid(GroupId) using btree,  key index_userid(groupid, UserId) using btree) default charset=utf8 comment '用戶組表';

2. 準備數據

var conStr = ConfigurationManager.ConnectionStrings["ConStr"].ToString();using (IDbConnection conn = new MySqlConnection(conStr)){ Stopwatch watch = new Stopwatch(); var sql = string.Empty; var names = new string[] { "非", "想", "紅", "帝", "德", "看", "梅", "插", "兔" }; Random ran = new Random();  var insertSql = @" insert into User(NickName,Sex,Sign, Birthday, CreateTime) values(@NickName,@Sex,@Sign, @Birthday, @CreateTime);  INSERT INTO usergroup (UserId, GroupId, CreateTime ) VALUES (LAST_INSERT_ID() , @GroupId, @CreateTime);"; watch.Start(); if (conn.State == ConnectionState.Closed) {  conn.Open(); } var tran = conn.BeginTransaction(); for (int i = 0; i < 100000; i++) {  var param = new { NickName = names[ran.Next(9)] + names[ran.Next(9)] + i, Sign = names[ran.Next(9)] + names[ran.Next(9)], CreateTime = DateTime.Now, Birthday = DateTime.Now.AddYears(ran.Next(10, 30)), Sex = i % 2, GroupId = ran.Next(1, 100) };  conn.Execute(insertSql, param, tran); } tran.Commit(); conn.Dispose(); watch.Stop(); Console.WriteLine(watch.ElapsedMilliseconds);}

這里我插入了5000條數據, group分了99個組, 隨機的.

3. 查詢sql

 explainselect user.id, user.nickname from usergroup left join user on usergroup.UserId = user.Idwhere usergroup.groupid = 1 order by usergroup.UserId desclimit 100, 20; explainselect user.id, user.nicknamefrom (select id, userid from usergroup where groupid = 1 order by userid limit 100, 20) tleft join user on t.UserId = user.id ; explainselect user.id, user.nicknamefrom (select id, userid from usergroup where groupid = 1 order by userid ) tleft join user on t.UserId = user.id limit 100, 20;

第二句和第三句都使用到了子查詢, 不同之處再與, 第二句是先得到20條數據, 然后以此來與user表關聯的

4. 分析

100000條數據情況下 :

先看第一句

mysql,性能優化,子查詢

再看第二句

mysql,性能優化,子查詢

第三句

mysql,性能優化,子查詢

從上面三幅圖看, 好像能看出點什么了.

首先看他們的 rows, 第二句最多, 加起來有1000多了, 另兩句加起來都是996. 但是我想說的是, 這里并不是看rows的和是多少. 正確的方式是, 從id大的語句開始看, id相同的語句, 從上到下依次執行.

那先看第二句的id=2的語句和第一句的id=1的語句, 一模一樣的. 他們都是從usergroup表中篩選數據, 并且能得到相同的結果集A.

看來他們都是基于相同的結果集去進行操作, 接下來就有區別了.

先看第一句, 再結果集A的基礎上, 去左連接表user, 并篩選出最后的數據, 返回給客戶端.

那第二句呢, 是在A的基礎上, 再次篩選數據, 得到需要的數據, 然后拿這些數據, 去與user表左連接, 得到最終結果.

從上面來看, 執行計劃中, 第二種執行計劃, 更加高效.

 如果能夠通過子查詢, 大幅度縮小查詢范圍, 可以考慮使用子查詢語句.

以上所述是小編給大家介紹的Mysql數據庫性能優化之子查詢,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日本欧美在线观看| 亚洲国产精彩中文乱码av在线播放| 国产成人精品久久久| 久久99国产综合精品女同| 欧美精品性视频| 亚洲欧美在线看| 伊人精品在线观看| 国产精品久久久久久久久久久久久| 国产亚洲精品久久久久久牛牛| 国产精品欧美日韩| 欧美整片在线观看| 欧美日韩一区免费| 亚洲成成品网站| 在线播放日韩av| 久久精品国产一区| 国产欧亚日韩视频| 91久久精品久久国产性色也91| 91av在线看| 久久99久久久久久久噜噜| 91在线精品视频| 欧美亚洲另类制服自拍| 国产亚洲精品久久久久久牛牛| 国产69精品久久久久久| 日韩久久午夜影院| 亚洲小视频在线观看| 91精品综合久久久久久五月天| 欧美午夜电影在线| 欧美亚洲国产日本| 久久国产天堂福利天堂| 狠狠操狠狠色综合网| 欧美日韩综合视频| 欧美一区三区三区高中清蜜桃| 国产精品海角社区在线观看| 亚洲成人国产精品| 国产成人综合av| 亚洲成人av资源网| 一本色道久久88亚洲综合88| 亚洲天堂成人在线视频| 九色精品美女在线| 日韩欧美一区二区在线| 亚洲综合大片69999| 91成人免费观看网站| 色综合伊人色综合网站| 欧美一级大胆视频| 国产亚洲激情视频在线| 久久亚洲精品成人| 国产精品白丝av嫩草影院| 亚洲在线免费看| 国产成人精品日本亚洲专区61| 日韩美女视频在线观看| 国内精品久久影院| 日韩av电影在线播放| 狠狠色狠狠色综合日日五| 久久久人成影片一区二区三区观看| 国产精品福利在线观看| 国产精品久久久久久久9999| 亚洲一区二区三区香蕉| 亚洲国产精品yw在线观看| 日韩av在线免费看| 中文字幕精品av| 久久久亚洲成人| 91在线视频导航| 亚洲欧美日韩视频一区| 亚洲japanese制服美女| 91国偷自产一区二区三区的观看方式| 欧美一级视频一区二区| 成人亚洲欧美一区二区三区| 日韩有码视频在线| 亚洲男人天堂2024| 国产丝袜精品第一页| 国产欧美va欧美va香蕉在线| 欧美激情欧美狂野欧美精品| 日韩激情视频在线| 欧美成人激情视频免费观看| 国内精品中文字幕| 久久久久久国产精品久久| 精品欧美激情精品一区| 欧美黑人巨大精品一区二区| 欧美视频在线免费| 日本欧美一级片| 91人人爽人人爽人人精88v| 亚洲视频专区在线| 日韩欧美国产中文字幕| 2019国产精品自在线拍国产不卡| 92国产精品久久久久首页| 国产精品成人品| 国产成人啪精品视频免费网| 91社影院在线观看| 欧美老女人性生活| 亚洲美女喷白浆| 久久精品国产欧美激情| 欧美在线播放视频| 亚洲人成电影网站色| 亚洲一区二区自拍| 狠狠色香婷婷久久亚洲精品| 国产啪精品视频网站| 日韩精品在线播放| 日韩精品在线电影| 精品国产一区二区在线| 亚洲国产精品电影在线观看| 欧美激情一区二区久久久| 欧美成人免费全部| 久久欧美在线电影| 久久伊人免费视频| 欧美在线一区二区视频| 国产精品视频一区二区高潮| 91在线观看免费高清| 成人激情电影一区二区| 亚洲天堂网站在线观看视频| 午夜精品久久久99热福利| 国产成人拍精品视频午夜网站| 欧美在线视频播放| 久久成人综合视频| 日韩中文字幕av| 免费不卡在线观看av| 91国语精品自产拍在线观看性色| 欧美亚洲视频在线看网址| 国产美女搞久久| 亚洲视频网站在线观看| 久久精品99无色码中文字幕| 亚洲国产成人精品久久| 国模吧一区二区| 国产精品久久久久久av福利软件| 日韩av一区二区在线观看| 国精产品一区一区三区有限在线| 亚洲综合日韩中文字幕v在线| 亚洲在线免费看| 国产精品精品一区二区三区午夜版| 中文字幕久久亚洲| 2019中文在线观看| 97热在线精品视频在线观看| 日韩电影中文字幕一区| 992tv成人免费视频| 色妞色视频一区二区三区四区| 色婷婷av一区二区三区久久| 亚洲成色www8888| 成人午夜两性视频| 国产91精品久久久久久| 红桃视频成人在线观看| 亚洲一区二区三区在线免费观看| 日韩欧美一区视频| 国产精品入口夜色视频大尺度| 久久免费少妇高潮久久精品99| 国产又爽又黄的激情精品视频| 激情成人中文字幕| 日韩中文有码在线视频| 亚洲国产精品推荐| 久久久999精品视频| 欧美国产日韩一区二区| 亚洲国产成人精品一区二区| 国产欧美日韩精品丝袜高跟鞋| 久久99精品久久久久久青青91| 亚洲精品日产aⅴ| 成人av资源在线播放| 色婷婷综合久久久久| 精品二区三区线观看| 欧洲亚洲在线视频| 国产精品电影网站| 国产日本欧美在线观看| 色偷偷av一区二区三区| 久久精品一本久久99精品| 欧美性xxxx极品高清hd直播| 亚洲小视频在线观看| 亚洲free性xxxx护士白浆|