Mysql 中给查询结果添加序号列,类似 oracle 中的 rownum

Mysql 中给查询结果添加序号列,类似 oracle 中的 rownum
select (@i:=@i+1)pm,s.* from stuscore s,(select @i:=0) t

思路:

事先定义一个变量,通过变量的递加以及虚拟表的联查达到生成序列号的目的。

select * from table1,table2 不加任何条件时,是把两个表的数据笛卡尔积之后显示,

如上 sql 中的 t 这张表 其实就是 一条 i=0 的数据

mysql 存储过程中,定义变量有两种方式:

  1. 使用 set 或 select 直接赋值,变量名以 @ 开头

赋值符号:使用 set 时可以用 “=“ 或者 “:=” 但是使用 select 赋值时必须使用 “:=” 赋值

例如: set@id=1;

可以在一个会话的任何地方声明,作用域是整个会话,称为会话变量。

mysql 总变量不用事先声明,在用的时候直接用 @变量名 使用即可

  1. 以 DECLARE 关键字声明的变量,只能在存储过程中使用,称为存储过程变量

例如:DECLARE var1 INT DEFAULT 0;

主要用在存储过程中,或者是给存储传参数中

两者的区别是:

在调用存储过程时,以 DECLARE 声明的变量都会被初始化为 NULL。

而会话变量(即@开头的变量)则不会被再初始化,在一个会话内,只须初始化一次,之后在会话内都是对上一次计算的结果,就相当于在是这个会话内的全局变量。

在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。

例:

set @v_sql= sqltext;
PREPARE stmt FROM @v_sql;  
EXECUTE stmt;     
DEALLOCATE PREPARE stmt;

参考:https://www.cnblogs.com/northern-light/p/8494711.html

猜你喜欢

转载自blog.csdn.net/weixin_41287692/article/details/84134725