• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mysql查询语句中用户变量的使用代码解析
    POST TIME:2021-10-18 21:01

    上一篇文章中我们介绍了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` , `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中or语句用法示例、详解MySQL数据类型DECIMAL(N,M)中N和M分别表示的含义等,有什么问题可以随时留言,小编会及时回复大家的。感谢朋友们对本站的支持!

    您可能感兴趣的文章:
    • mysql变量用法实例分析【系统变量、用户变量】
    • mysql用户变量与set语句示例详解
    上一篇:详解MySQL数据类型DECIMAL(N,M)中N和M分别表示的含义
    下一篇:mysql中使用instr进行模糊查询方法介绍
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信