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)asrow_count, @v_fid:=a.fid from ( SELECT id, fid, has_read, notice_time, read_time FROMvkm_user_notice_flight where`notice_type`='process_update'anduid=82 orderbyfid,notice_timedesc )a, ( select@v_rownum:=0,@v_rowid:=0,@v_fid:=null )b )t wheret.row_count=1 )AS`notice` LEFTJOIN`vkm_flight`AS`f`ON`notice`.`fid`=`f`.`id` LEFTJOIN`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`LEFTJOIN`vkm_flight`AS`f`ON`notice`.`fid`=`f`.`id`LEFTJOIN`vkm_parking`AS`parking`ON`f`.`actual_parking`=`parking`.`parking_num`
但是以上代码的查询效率真的是差别太大了!具体的上面的那串代码我还没明白方式,也请求指导中,但是上网百度了一下一个是mysql中if的使用还有一个就是mysql中用户变量的使用
用户名量的设置可以通过setvarvalue的方式也可以用以上的形式@var:=val;
mysql中if的使用if(exp1,exp2,exp3)在if中如果exp1为true则执行exp2否则执行exp3;
现在再看上述的代码的话可能就简单多了!根据上述的代码我又重新自己写了一个简单的应用实例
selectid,fnum,forg,fdst,@v_rownum:=@v_rownum+1fromvkm_flight,(select@v_rownum:=0)b
这样就返回了@v_rownum的值
以上就是本文关于mysql查询语句中用户变量的使用代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站:MySQL中or语句用法示例、详解MySQL数据类型DECIMAL(N,M)中N和M分别表示的含义等,有什么问题可以随时留言,小编会及时回复大家的。感谢朋友们对本站的支持!