mysql查詢語(yǔ)句中用戶變量的使用代碼解析
上一篇文章中我們介紹了MySQL優(yōu)化總結(jié)-查詢總條數(shù)。這篇文章我們來(lái)介紹下查詢語(yǔ)句中的另一個(gè)知識(shí):用戶變量的使用代碼解析。
先上代碼吧
SELECT `notice`.`id` , `notice`.`fid` , `notice`.`has_read` , `notice`.`notice_time` , `notice`.`read_time` , `f`.`fnum` , `f`.`forg` , `f`.`fdst` , `f`.`actual_parking` AS `parking` , `f`.`scheduled_deptime` , `f`.`estimated_deptime` , `f`.`actual_deptime` , `f`.`scheduled_arrtime` , `f`.`estimated_arrtime` , `f`.`actual_arrtime` , `f`.`is_vip` , `f`.`aoc_notice` FROM ( select t.id, t.fid, t.has_read, t.notice_time, t.read_time from ( select a.id, a.fid, a.has_read, a.notice_time, a.read_time, @v_rownum := @v_rownum+1, if(@v_fid=a.fid,@v_rowid:=@v_rowid+1,@v_rowid:=1 ) as row_count, @v_fid:=a.fid from ( SELECT id, fid, has_read, notice_time, read_time FROM vkm_user_notice_flight where `notice_type` = 'process_update' and uid=82 order by fid, notice_time desc ) a, ( select @v_rownum:=0, @v_rowid:=0, @v_fid:=null ) b ) t where t.row_count =1 ) AS `notice` LEFT JOIN `vkm_flight` AS `f` ON `notice`.`fid` = `f`.`id` LEFT JOIN `vkm_parking` AS `parking` ON `f`.`actual_parking` = `parking`.`parking_num`
在工作中朋友發(fā)來(lái)了一段這樣的sql語(yǔ)句 一開(kāi)始我 就蒙了 根本不懂?。∫?yàn)閭€(gè)人的mysql也不是很精通只會(huì)簡(jiǎn)單的增刪改而已其實(shí),以上代碼很直接的寫(xiě)法就是
SELECT `notice`.`id` , `notice`.`fid` , `notice`.`has_read` , `notice`.`notice_time` , `notice`.`read_time` , `f`.`fnum` , `f`.`forg` , `f`.`fdst` , `f`.`actual_parking` AS `parking` , `f`.`scheduled_deptime` , `f`.`estimated_deptime` , `f`.`actual_deptime` , `f`.`scheduled_arrtime` , `f`.`estimated_arrtime` , `f`.`actual_arrtime` , `f`.`is_vip` , `f`.`aoc_notice` FROM `notice` LEFT JOIN `vkm_flight` AS `f` ON `notice`.`fid` = `f`.`id` LEFT JOIN `vkm_parking` AS `parking` ON `f`.`actual_parking` = `parking`.`parking_num`
但是以上代碼的查詢效率真的是差別太大了!具體的上面的那串代碼我還沒(méi)明白方式,也請(qǐng)求指導(dǎo)中,但是上網(wǎng)百度了一下 一個(gè)是mysql中if的使用還有一個(gè)就是mysql中用戶變量的使用
用戶名量的設(shè)置可以通過(guò)set var value的方式也可以用以上的形式@var:=val;
mysql中if的使用if(exp1,exp2,exp3) 在if中如果exp1為true則執(zhí)行exp2否則執(zhí)行exp3;
現(xiàn)在再看上述的代碼的話可能就簡(jiǎn)單多了!根據(jù)上述的代碼我又重新自己寫(xiě)了一個(gè)簡(jiǎn)單的應(yīng)用實(shí)例
select id,fnum,forg,fdst,@v_rownum:=@v_rownum+1 from vkm_flight,(select @v_rownum:=0) b
這樣就返回了@v_rownum的值
總結(jié)
以上就是本文關(guān)于mysql查詢語(yǔ)句中用戶變量的使用代碼解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:MySQL中or語(yǔ)句用法示例、詳解MySQL數(shù)據(jù)類型DECIMAL(N,M)中N和M分別表示的含義等,有什么問(wèn)題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家的。感謝朋友們對(duì)本站的支持!
相關(guān)文章
Mysql 忘記root密碼和修改root密碼的解決方法(小結(jié))
這篇文章主要介紹了Mysql 忘記root密碼和修改root密碼的解決方法(小結(jié)),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-12-12Mysql事務(wù)的隔離級(jí)別(臟讀+幻讀+可重復(fù)讀)
這篇文章主要介紹了Mysql事務(wù)的隔離級(jí)別(臟讀+幻讀+可重復(fù)讀),文章通告InnoDB展開(kāi)詳細(xì)內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2022-08-08mysql數(shù)據(jù)類型和字段屬性原理與用法詳解
這篇文章主要介紹了mysql數(shù)據(jù)類型和字段屬性,結(jié)合實(shí)例形式分析了mysql數(shù)據(jù)類型和字段屬性基本概念、原理、分類、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04幾個(gè)縮減MySQL以節(jié)省磁盤(pán)空間的建議
這篇文章主要介紹了幾個(gè)縮減MySQL以節(jié)省磁盤(pán)空間的建議,主要從表結(jié)構(gòu)和存儲(chǔ)內(nèi)容兩個(gè)方面來(lái)談減容,需要的朋友可以參考下2015-05-05MHA實(shí)現(xiàn)mysql主從數(shù)據(jù)庫(kù)手動(dòng)切換的方法
這篇文章主要介紹了MHA實(shí)現(xiàn)mysql主從數(shù)據(jù)庫(kù)手動(dòng)切換的方法,詳細(xì)的講述了主從數(shù)據(jù)庫(kù)切換的步驟與方法,非常實(shí)用,需要的朋友可以參考下2014-10-10MySQL中使用or、in與union all在查詢命令下的效率對(duì)比
這篇文章主要介紹了MySQL中使用or、in與union all在查詢命令下的效率對(duì)比,論證了在通常情況下union all并不一定比or及in更快,需要的朋友可以參考下2015-11-11