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:[email protected]_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:[email protected]_rownum+1 from vkm_flight,(select @v_rownum:=0) b

这样就返回了@v_rownum的值

时间: 2024-08-11 03:38:30

mysql查询语句中用户变量的使用的相关文章

mysql查询语句中自定义变量(转)

转:http://blog.sina.com.cn/s/blog_1512521570102wrfl.htmlselect cost,@a:[email protected]+1 from testone,(select @a:=0) as a; mysql中变量不用事前申明,在用的时候直接用"@变量名"使用就可以了. 第一种用法:set @num=1; 或set @num:=1; //这里要使用变量来保存数据,直接使用@num变量 第二种用法:select @num:=1; 或 se

mysql查询语句中使用星号真的慢的要死?

前言 之所以写这篇文章,是源于以前看过的关于sql语句优化的帖子,里面明确提到了在sql语句中不要使用 * 来做查询,就像下面的规则中说的 2.尽量避免使用select *,返回无用的字段会降低查询效率.如下: SELECT * FROM t 优化方式:使用具体的字段代替*,只返回使用到的字段. 但是中国有句姥话叫“尽信书不如无书”,难道在sql查询语句中使用星号就真的慢的要死,难道加索引也不行?带着这些个疑问,我进行了一些测试.结果发现,江湖传说未必真的靠得住.那具体测试情况是咋样的呢?下面且

MySQL 查询语句中自己定义的中文内容在Java Web 中显示为问号

Java Web 端做查询时,性别字段存的是数字,1代表男,2代表女,取数据时将性别转为汉字显示在页面,sql语句如下,结果发生了问题 select a.emp_id,a.emp_name ,case when a.emp_gendar=1 then '男' when a.emp_gendar=2 then '女' end as emp_gendar, b.post_namefrom  t_employee_info a, t_position_info bwhere a.post_id = b

mysql 查询语句中去除回车和换行

SELECT REPLACE(name, '\\n', '') FROM table_name; SELECT REPLACE(name, '\\n', '') FROM table_name; 原文地址:https://www.cnblogs.com/ZhangYaF/p/9486026.html

mysql常用内置函数-查询语句中不能使用strtotime()函数!

来自:http://yushine.iteye.com/blog/775407 FROM_UNIXTIME把 unix时间戳转换为标准时间 unix_timestamp把标准时间转换为 unix时间戳//查询语句中不能使用strtotime()函数!但是可以使用unix_timestamp DATE_FORMAT('1997-10-04 22:23:00','%Y-%m-%d') 格式化时间 如:select FROM_UNIXTIME(pubdate) from article where p

mysql查询语句

mysql查询语句常用SELECT命令打印当前的日期和时间select now();打印当前的日期select curdate();打印当前时间select curtime();查看当前版本select version();打印当前用户select user();查看当前数据库实例select database();查看系统中可用的变量show variables;查看系统中全局变量show global variables;一般查询系统可用变量或是全局变量都是通过like的方式来进行查询的,因

MySQL 查询语句select讲解与练习

select语句执行流程: START---->FROM------>WHERE(选择,合适的行)--------->GROUP BY(分组)---------->HAVING(对分组进行过滤)---->ORDER BY(排序)---->SELECT(投影,合适的字段)---->LIMIT---->end result select单表查询: DISTINCT:数据去重 例:select DISTINCT gender from students; VARI

MySQL 查询语句执行顺序

Mysql查询语句时候一共分为11步,其中每一个操作都会产生一张虚拟的表,这个虚拟的表作为一个处理的输入,只是这些虚拟的表对用户来说是透明的,但是只有最后一个虚拟的表才会被作为结果返回. 语句执行顺序 : 顺序 名称 内容 1 SELECT 命令发起 2 * 或 AVG(字段)等 查询内容 3 FROM 查询位置 4 WHERE 条件查询 5 GROUP BY 分组 6 HAVING 筛选 7 ORDER BY (ASC/DESC) 排序 8 LIMIT 限制结果数 1.单表查询 查询指定的列

MySQL 5.6中的变量

这篇文章介绍的是MySQL  5.6中的变量,基本是我以前学习MySQL 5.6手册时整理而来. 基础概念 MySQL中的变量可分为以下几种: 1. MySQL系统变量:该类型变量反映了MySQL服务器是如何配置的.每一个系统变量都有一个默认值.系统变量可以在MySQL配置文件中进行设置,或使用MySQL启动选项进行设置.大多数系统变量都可以在MySQL运行时使用SET命令进行动态修改. 2. MySQL状态变量:该类型变量反映了MySQL服务器的运行状态. 变量按作用范围可分为: 1. 全局变