国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

Mysql join聯(lián)表及id自增實(shí)例解析

瀏覽:143日期:2023-10-11 16:23:39

join的寫法

如果用left join 左邊的表一定是驅(qū)動(dòng)表嗎?兩個(gè)表的join包含多個(gè)條件的等值匹配,都要寫道on還是只把一個(gè)寫到on,其余寫道where部分?

createtablea(f1int,f2int,index(f1))engine=innodb; createtableb(f1int,f2int)engine=innodb; insertintoavalues(1,1),(2,2),(3,3),(4,4),(5,5),(6,6); insertintobvalues(3,3),(4,4),(5,5),(6,6),(7,7),(8,8);select*fromaleftjoinbon(a.f1=b.f1)and(a.f2=b.f2);/*Q1*/ select*fromaleftjoinbon(a.f1=b.f1)where(a.f2=b.f2);/*Q2*/

執(zhí)行結(jié)果:

Mysql join聯(lián)表及id自增實(shí)例解析

由于表b沒有索引,使用的是Block Nexted Loop Join(BNL)算法

把表a的內(nèi)容讀入join_buffer中,因?yàn)閟elect * ,所以字段f1,f2都被放入 順序掃描b,對(duì)于每一行數(shù)據(jù),判斷join條件是否滿足,滿足條件的記錄,作為結(jié)果集的一行,如果有where子句,判斷where部分滿足條件后再返回。 表b掃描完成后,對(duì)于沒有匹配的表a的行,用null補(bǔ)上,放到結(jié)果集中。

Mysql join聯(lián)表及id自增實(shí)例解析

Q2語句中,explain結(jié)果:

Mysql join聯(lián)表及id自增實(shí)例解析

b為驅(qū)動(dòng)表,如果一條語句EXTRA字段什么都沒有的話,就是Index Nested_Loop Join算法,因此流程是:

順序掃描b,每一行用b.f1到a中去查,匹配a.f2=b.f2是否滿足,作為結(jié)果集返回。

Q1與Q2執(zhí)行流程的差異是因?yàn)閮?yōu)化器基于Q2這個(gè)查詢語義做了優(yōu)化:在mysql里,null跟任何值執(zhí)行等值判斷和不等值判斷的結(jié)果都是null,包括select null = null 也返回null。

在Q2中,where a.f2 = b.f2表示,查詢結(jié)果里不會(huì)包含b.f2是null的行,這樣left join語義就是找到兩個(gè)表里f1 f2對(duì)應(yīng)相同的行,如果a存在而b匹配不到,就放棄。因此優(yōu)化器把這條語句的left join改寫成了join,因?yàn)閍的f1有索引,就把b作為驅(qū)動(dòng)表,這樣可以用NLJ算法,所以在使用left join時(shí),左邊的表不一定是驅(qū)動(dòng)表。

如果需要left join的語義,就不能把被驅(qū)動(dòng)表的字段放在where條件里做等值判斷或不等值判斷,必須寫在on里面。

Nested Loop Join的性能問題

BLN算法的執(zhí)行邏輯

將驅(qū)動(dòng)表的數(shù)據(jù)全部讀入join_buffer中,里面是無序數(shù)組。 順序遍歷被驅(qū)動(dòng)表的所有行,每一行都跟join_buffer做匹配,成功則作為結(jié)果集的一部分返回。

Simple Nested Loop Join算法邏輯是:順序去除驅(qū)動(dòng)表的每一行數(shù)據(jù),到被驅(qū)動(dòng)表做全表匹配。

兩者差異:

在對(duì)被驅(qū)動(dòng)表做全表掃描時(shí),如果數(shù)據(jù)沒有在buffer pool中,需要等待部分?jǐn)?shù)據(jù)從磁盤讀入。會(huì)影響正常業(yè)務(wù)的buffer pool命中率,而且會(huì)對(duì)被驅(qū)動(dòng)表做多次訪問,更容易將這些數(shù)據(jù)頁放到buffer pool頭部。所以BNL算法性能會(huì)更好。自增id

mysql中自增id定義了初始值,不停的增長,但是有上限,2^32-1,自增的id用完了會(huì)怎么樣呢。

表定義的自增值達(dá)到上限后,再申請(qǐng)下一個(gè)id時(shí),得到的值保持不變。再次插入時(shí)會(huì)報(bào)主鍵沖突錯(cuò)誤。所以在建表時(shí),如果有頻繁的增刪改時(shí),就應(yīng)該創(chuàng)建8個(gè)字節(jié)的bigint unsigned。

innodb 系統(tǒng)自增row_id

如果創(chuàng)建了Innodb表沒有指定主鍵,那么innodb會(huì)創(chuàng)建一個(gè)不可見的,長度為6個(gè)字節(jié)的row_id,所有無主鍵的innodb表,每插入一行數(shù)據(jù),都將當(dāng)前的dict_sys.row_id值作為要插入數(shù)據(jù)的row_id,然后自增1。

實(shí)際上,代碼實(shí)現(xiàn)時(shí),row_id是一個(gè)長度為8字節(jié)的無符號(hào)長整形,但是innodb在設(shè)計(jì)時(shí),給row_id只是6個(gè)字節(jié)的長度,這樣寫道數(shù)據(jù)時(shí)只放了最后6個(gè)字節(jié)。所以:

row_id寫入表的范圍是0到2^48-1; 當(dāng)達(dá)到最大時(shí),如果再有插入數(shù)據(jù)的行為來申請(qǐng)row_id,拿到以后再去最后6個(gè)字節(jié)就是0,然后繼續(xù)循環(huán)。 再innodb的邏輯里,達(dá)到最大后循環(huán),新數(shù)據(jù)會(huì)覆蓋已經(jīng)存在的數(shù)據(jù)。

從這個(gè)角度看,我們應(yīng)該主動(dòng)創(chuàng)建自增主鍵,這樣達(dá)到上限后,插入數(shù)據(jù)會(huì)報(bào)錯(cuò)。數(shù)據(jù)的可靠性會(huì)更加有保障。

XID

redo log 和 binlog相互配合的時(shí)候,它們有一個(gè)共同的字段就是xid,在mysql中對(duì)應(yīng)事務(wù)的。xid最大時(shí)2^64次方,用盡只存在理論。

thread_id

系統(tǒng)保存了全局變量thread_id_counter,每新建一個(gè)連接,就將thread_id_counter賦值給這個(gè)新連接的線程變量。thread_id_counter定義的大小是4個(gè)字節(jié),因此到2^32-1就會(huì)重置為0,然后繼續(xù)增加。但是show processlist里不會(huì)看到兩個(gè)相同的thread_id,這是因?yàn)閙ysql設(shè)計(jì)了一個(gè)唯一數(shù)組邏輯,給新線程分配thread_id的時(shí)候:

do{ new_id=thread_id_counter++; }while(!thread_ids.insert_unique(new_id).second);

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 亚洲精品二区 | 亚洲国产品综合人成综合网站 | 99久女女精品视频在线观看 | 97国产精品欧美一区二区三区 | 亚洲人成网站色7799在线观看 | 国产亚洲一区二区手机在线观看 | 国产一级淫片a免费播放口之 | 在线 | 一区二区三区 | 欧美91精品久久久久网免费 | 欧美精品一区二区三区免费观看 | 亚洲另类自拍 | 亚洲欧美精品一中文字幕 | 久久精品国产91久久综合麻豆自制 | 久久久9视频在线观看 | 精品综合久久久久久98 | 久久香蕉国产线看免费 | 久久国产情侣 | 亚洲精品综合一区在线 | 中文字幕有码视频 | 欧美一区二区三区国产精品 | 特级毛片aaaa免费观看 | 在线免费观看色 | 欧美国产日韩在线观看 | 精品国产日韩久久亚洲 | 99国产国人青青视频在线观看 | 欧美色大成网站www永久男同 | 欧美一级大片在线观看 | 亚洲欧美久久 | 高清性色生活片欧美在线 | 色情毛片 | 国产日韩欧美在线观看不卡 | 在线播放高清国语自产拍免费 | 中文在线免费视频 | 欧美一级久久久久久久久大 | 日韩不卡一区二区三区 | 国产精彩视频在线观看 | 欧美一级在线观看视频 | 欧美高清不卡 | 两性色午夜视频免费国产 | 七七国产福利在线二区 | 99久久免费国产精品 |