mysql查詢語句中用戶變量的使用代碼解析
上一篇文章中我們介紹了MySQL優(yōu)化總結-查詢總條數(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ā)來了一段這樣的sql語句 一開始我 就蒙了 根本不懂?。∫驗閭€人的mysql也不是很精通只會簡單的增刪改而已其實,以上代碼很直接的寫法就是
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`
但是以上代碼的查詢效率真的是差別太大了!具體的上面的那串代碼我還沒明白方式,也請求指導中,但是上網(wǎng)百度了一下 一個是mysql中if的使用還有一個就是mysql中用戶變量的使用
用戶名量的設置可以通過set var value的方式也可以用以上的形式@var:=val;
mysql中if的使用if(exp1,exp2,exp3) 在if中如果exp1為true則執(zhí)行exp2否則執(zhí)行exp3;
現(xiàn)在再看上述的代碼的話可能就簡單多了!根據(jù)上述的代碼我又重新自己寫了一個簡單的應用實例
select id,fnum,forg,fdst,@v_rownum:=@v_rownum+1 from vkm_flight,(select @v_rownum:=0) b
這樣就返回了@v_rownum的值
總結
以上就是本文關于mysql查詢語句中用戶變量的使用代碼解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:MySQL中or語句用法示例、詳解MySQL數(shù)據(jù)類型DECIMAL(N,M)中N和M分別表示的含義等,有什么問題可以隨時留言,小編會及時回復大家的。感謝朋友們對本站的支持!
版權聲明:本站文章來源標注為YINGSOO的內(nèi)容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。
關注官方微信