1. 程式人生 > 資料庫 >mysql查詢語句中使用者變數的使用程式碼解析

mysql查詢語句中使用者變數的使用程式碼解析

上一篇文章中我們介紹了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 (
  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`

在工作中朋友發來了一段這樣的sql語句 一開始我 就蒙了 根本不懂啊!因為個人的mysql也不是很精通只會簡單的增刪改而已其實,以上程式碼很直接的寫法就是

SELECT `notice`.`id`,`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`

但是以上程式碼的查詢效率真的是差別太大了!具體的上面的那串程式碼我還沒明白方式,也請求指導中,但是上網百度了一下 一個是mysql中if的使用還有一個就是mysql中使用者變數的使用

使用者名稱量的設定可以通過set var value的方式也可以用以上的形式@var:=val;

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

現在再看上述的程式碼的話可能就簡單多了!根據上述的程式碼我又重新自己寫了一個簡單的應用例項

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

這樣就返回了@v_rownum的值

總結

以上就是本文關於mysql查詢語句中使用者變數的使用程式碼解析的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站:MySQL中or語句用法示例、詳解MySQL資料型別DECIMAL(N,M)中N和M分別表示的含義等,有什麼問題可以隨時留言,小編會及時回覆大家的。感謝朋友們對本站的支援!