加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

mysql查询语句中用户变量的使用代码解析

发布时间:2020-12-12 07:20:13 所属栏目:MsSql教程 来源:网络整理
导读:上一篇文章中我们介绍了MySQL优化总结-查询总条数。这篇文章我们来介绍下查询语句中的另一个知识:用户变量的使用代码解析。 先上代码吧 SELECT `notice`.`id`,`notice`.`fid`,`notice`.`has_read`,`notice`.`notice_time`,`notice`.`read_time`,`f`.`fnum`,

上一篇文章中我们介绍了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分别表示的含义等,有什么问题可以随时留言,小编会及时回复大家的。感谢朋友们对本站的支持!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读