oracle添加序号
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle添加序号相关的知识,希望对你有一定的参考价值。
用rownum可以加 但碰到group by 之后加的顺序是乱的 如何解决啊
比如你要按name 进行group by ,然后按name排序
select row_number() over (order by name) rn,name,sum(计算值) from 表名 group by name 参考技术A 建立1个表,多个id字段,且自增,将你的数据插入过去,如果需要的话,可以根据这个id字段更新你原表的排序字段 参考技术B rownum函数作用的column不可以用groupby排序的。mysql中给查询结果添加序号列
生成一个字段(非表中字段)用以记录排序 【类比为oracle数据库中的rownum】
MySQL中一个表(表名:stuscore)
字段有:id(主键)、stuid(学号)、sname(学生姓名)、subject(课程名称)、score(分数)
列出数学成绩排名 (要求显示字段:排名,姓名 , 课程名称, 分数 , 学号)
用于排名的字段,查询时此处将其用 pm表示
select (@i:=@i+1)pm,s.* from stuscore s,(select @i:=0)t where s.subject=\'数学\'
order by score desc;
思想:事先定义一个变量,通过变量的递加以及虚拟表的联查达到生成序列号的目的。
select * from table1,table2 不加任何条件时,是把两个表的数据笛卡尔积之后显示,
如上sql中的 t 这张表 其实就是 一条 i=0 的数据
mysql存储过程中,定义变量有两种方式:
1、使用set或select直接赋值,变量名以 @开头
赋值符号:使用set 时可以用 “=“或者“:=” 但是使用select赋值时必须使用“:=”赋值
例如: set@id=1;
可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。
mysql总变量不用事先声明,在用的时候直接用@变量名 使用即可
【先行记录】
2、以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量,例如:
DECLARE var1 INT DEFAULT 0;
主要用在存储过程中,或者是给存储传参数中
两者的区别是:
在调用存储过程时,以DECLARE声明的变量都会被初始化为 NULL。而会话变量(即@开头的变量)则
不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在
是这个会话内的全局变量。
在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。
例:
set @v_sql= sqltext;
PREPARE stmt FROM @v_sql;
EXECUTE stmt;
DEALLOCATE PREPARE stmt;
以上是关于oracle添加序号的主要内容,如果未能解决你的问题,请参考以下文章