主頁 > 知識庫 > mysql查詢語句中用戶變量的使用代碼解析

mysql查詢語句中用戶變量的使用代碼解析

熱門標簽:怎么辦理400電話呢 怎么申請400電話申請 百度地圖標注地方備注 電話機器人免費嗎 好搜地圖標注 400電話申請什么好 地圖標注圖標素材入駐 電銷機器人價格多少錢一臺 龍圖酒吧地圖標注

上一篇文章中我們介紹了MySQL優(yōu)化總結(jié)-查詢總條數(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`

但是以上代碼的查詢效率真的是差別太大了!具體的上面的那串代碼我還沒明白方式,也請求指導(dǎo)中,但是上網(wǎng)百度了一下 一個是mysql中if的使用還有一個就是mysql中用戶變量的使用

用戶名量的設(shè)置可以通過set var value的方式也可以用以上的形式@var:=val;

mysql中if的使用if(exp1,exp2,exp3) 在if中如果exp1為true則執(zhí)行exp2否則執(zhí)行exp3;

現(xiàn)在再看上述的代碼的話可能就簡單多了!根據(jù)上述的代碼我又重新自己寫了一個簡單的應(yīng)用實例

select id,fnum,forg,fdst,@v_rownum:=@v_rownum+1 from vkm_flight,(select @v_rownum:=0) b

這樣就返回了@v_rownum的值

總結(jié)

以上就是本文關(guān)于mysql查詢語句中用戶變量的使用代碼解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:MySQL中or語句用法示例、詳解MySQL數(shù)據(jù)類型DECIMAL(N,M)中N和M分別表示的含義等,有什么問題可以隨時留言,小編會及時回復(fù)大家的。感謝朋友們對本站的支持!

您可能感興趣的文章:
  • mysql變量用法實例分析【系統(tǒng)變量、用戶變量】
  • mysql用戶變量與set語句示例詳解

標簽:浙江 防疫工作 固原 溫州 汕尾 內(nèi)江 廣西 撫順

巨人網(wǎng)絡(luò)通訊聲明:本文標題《mysql查詢語句中用戶變量的使用代碼解析》,本文關(guān)鍵詞  mysql,查詢,語句,中,用戶,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql查詢語句中用戶變量的使用代碼解析》相關(guān)的同類信息!
  • 本頁收集關(guān)于mysql查詢語句中用戶變量的使用代碼解析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章