电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Mysql join聯表及id自增實例解析

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

join的寫法

如果用left join 左邊的表一定是驅動表嗎?兩個表的join包含多個條件的等值匹配,都要寫道on還是只把一個寫到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*/

執行結果:

Mysql join聯表及id自增實例解析

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

把表a的內容讀入join_buffer中,因為select * ,所以字段f1,f2都被放入 順序掃描b,對于每一行數據,判斷join條件是否滿足,滿足條件的記錄,作為結果集的一行,如果有where子句,判斷where部分滿足條件后再返回。 表b掃描完成后,對于沒有匹配的表a的行,用null補上,放到結果集中。

Mysql join聯表及id自增實例解析

Q2語句中,explain結果:

Mysql join聯表及id自增實例解析

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

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

Q1與Q2執行流程的差異是因為優化器基于Q2這個查詢語義做了優化:在mysql里,null跟任何值執行等值判斷和不等值判斷的結果都是null,包括select null = null 也返回null。

在Q2中,where a.f2 = b.f2表示,查詢結果里不會包含b.f2是null的行,這樣left join語義就是找到兩個表里f1 f2對應相同的行,如果a存在而b匹配不到,就放棄。因此優化器把這條語句的left join改寫成了join,因為a的f1有索引,就把b作為驅動表,這樣可以用NLJ算法,所以在使用left join時,左邊的表不一定是驅動表。

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

Nested Loop Join的性能問題

BLN算法的執行邏輯

將驅動表的數據全部讀入join_buffer中,里面是無序數組。 順序遍歷被驅動表的所有行,每一行都跟join_buffer做匹配,成功則作為結果集的一部分返回。

Simple Nested Loop Join算法邏輯是:順序去除驅動表的每一行數據,到被驅動表做全表匹配。

兩者差異:

在對被驅動表做全表掃描時,如果數據沒有在buffer pool中,需要等待部分數據從磁盤讀入。會影響正常業務的buffer pool命中率,而且會對被驅動表做多次訪問,更容易將這些數據頁放到buffer pool頭部。所以BNL算法性能會更好。自增id

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

表定義的自增值達到上限后,再申請下一個id時,得到的值保持不變。再次插入時會報主鍵沖突錯誤。所以在建表時,如果有頻繁的增刪改時,就應該創建8個字節的bigint unsigned。

innodb 系統自增row_id

如果創建了Innodb表沒有指定主鍵,那么innodb會創建一個不可見的,長度為6個字節的row_id,所有無主鍵的innodb表,每插入一行數據,都將當前的dict_sys.row_id值作為要插入數據的row_id,然后自增1。

實際上,代碼實現時,row_id是一個長度為8字節的無符號長整形,但是innodb在設計時,給row_id只是6個字節的長度,這樣寫道數據時只放了最后6個字節。所以:

row_id寫入表的范圍是0到2^48-1; 當達到最大時,如果再有插入數據的行為來申請row_id,拿到以后再去最后6個字節就是0,然后繼續循環。 再innodb的邏輯里,達到最大后循環,新數據會覆蓋已經存在的數據。

從這個角度看,我們應該主動創建自增主鍵,這樣達到上限后,插入數據會報錯。數據的可靠性會更加有保障。

XID

redo log 和 binlog相互配合的時候,它們有一個共同的字段就是xid,在mysql中對應事務的。xid最大時2^64次方,用盡只存在理論。

thread_id

系統保存了全局變量thread_id_counter,每新建一個連接,就將thread_id_counter賦值給這個新連接的線程變量。thread_id_counter定義的大小是4個字節,因此到2^32-1就會重置為0,然后繼續增加。但是show processlist里不會看到兩個相同的thread_id,這是因為mysql設計了一個唯一數組邏輯,給新線程分配thread_id的時候:

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 福州时代广告制作装饰有限公司-福州广告公司广告牌制作,福州展厅文化墙广告设计, | 青岛侦探_青岛侦探事务所_青岛劝退小三_青岛婚外情取证-青岛王军侦探事务所 | 节流截止放空阀-不锈钢阀门-气动|电动截止阀-鸿华阀门有限公司 | 台式核磁共振仪,玻璃软化点测定仪,旋转高温粘度计,测温锥和测温块-上海麟文仪器 | 防腐储罐_塑料储罐_PE储罐厂家_淄博富邦滚塑防腐设备科技有限公司 | 北京康百特科技有限公司-分子蒸馏-短程分子蒸馏设备-实验室分子蒸馏设备 | 定制液氮罐_小型气相液氮罐_自增压液氮罐_班德液氮罐厂家 | SMC-ASCO-CKD气缸-FESTO-MAC电磁阀-上海天筹自动化设备官网 | 艺术涂料|木纹漆施工|稻草漆厂家|马来漆|石桦奴|水泥漆|选加河南天工涂料 | 酒瓶_酒杯_玻璃瓶生产厂家_徐州明政玻璃制品有限公司 | 石栏杆_青石栏杆_汉白玉栏杆_花岗岩栏杆 - 【石雕之乡】点石石雕石材厂 | VI设计-LOGO设计公司-品牌设计公司-包装设计公司-导视设计-杭州易象设计 | 深圳网站建设-高端企业网站开发-定制网页设计制作公司 | 黑龙江京科脑康医院-哈尔滨精神病医院哪家好_哈尔滨精神科医院排名_黑龙江精神心理病专科医院 | 实体店商新零售|微赢|波后|波后合作|微赢集团 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 天津仓储物流-天津电商云仓-天津云仓一件代发-博程云仓官网 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 智慧物联网行业一站式解决方案提供商-北京东成基业 | 手板-手板模型-手板厂-手板加工-生产厂家,[东莞创域模型] | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 十字轴_十字轴万向节_十字轴总成-南京万传机械有限公司 | 千斤顶,液压千斤顶-力良企业,专业的液压千斤顶制造商,shliliang.com | 许昌奥仕达自动化设备有限公司| 耐磨陶瓷管道_除渣器厂家-淄博浩瀚陶瓷科技有限公司 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | 交流伺服电机|直流伺服|伺服驱动器|伺服电机-深圳市华科星电气有限公司 | 99文库_实习生实用的范文资料文库站| 电缆接头-防爆电缆接头-格兰头-金属电缆接头-防爆填料函 | 办公室家具_板式办公家具定制厂家-FMARTS福玛仕办公家具 | 上海噪音治理公司-专业隔音降噪公司-中广通环保 | 济南电缆桥架|山东桥架-济南航丰实业有限公司 | 碳化硅,氮化硅,冰晶石,绢云母,氟化铝,白刚玉,棕刚玉,石墨,铝粉,铁粉,金属硅粉,金属铝粉,氧化铝粉,硅微粉,蓝晶石,红柱石,莫来石,粉煤灰,三聚磷酸钠,六偏磷酸钠,硫酸镁-皓泉新材料 | X光检测仪_食品金属异物检测机_X射线检测设备_微现检测 | 重庆小面培训_重庆小面技术培训学习班哪家好【终身免费复学】 | 广东成考网-广东成人高考网 | 气动机械手-搬运机械手-气动助力机械手-山东精瑞自动化设备有限公司 | 珠光砂保温板-一体化保温板-有釉面发泡陶瓷保温板-杭州一体化建筑材料 | TPE_TPE热塑性弹性体_TPE原料价格_TPE材料厂家-惠州市中塑王塑胶制品公司- 中塑王塑胶制品有限公司 | 立式矫直机_卧式矫直机-无锡金矫机械制造有限公司 |