国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

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

2024-07-24 13:14:52
字體:
來源:轉載
供稿:網友

上一篇文章中我們介紹了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/276136.html">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`

但是以上代碼的查詢效率真的是差別太大了!具體的上面的那串代碼我還沒明白方式,也請求指導中,但是上網百度了一下 一個是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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 洛扎县| 晋州市| 广元市| 大悟县| 浦江县| 昆明市| 左权县| 永兴县| 绥滨县| 平江县| 湖南省| 寿宁县| 新密市| 阳山县| 华池县| 唐海县| 英超| 清水河县| 清丰县| 逊克县| 峨眉山市| 武邑县| 祁东县| 裕民县| 建瓯市| 璧山县| 安平县| 虎林市| 克什克腾旗| 磐石市| 灵川县| 定远县| 临朐县| 年辖:市辖区| 吐鲁番市| 仁布县| 巴林右旗| 和平县| 西城区| 临城县| 四子王旗|