• 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;

      

    人生没有彩排,每天都是现场直播!
  • 相关阅读:
    时钟同步显示屏(NTP时间显示屏)子母钟系统介绍
    NTP服务器(时钟服务器)为金融交通行业保驾护航
    Moco server Linux 端部署
    Linux 系统下搭建 Gitlab 服务器
    CentOS7 防火墙设置命令
    Allure 环境安装
    Pytest allure 生成测试报告
    Pytest allure 定制化测试报告
    Pytest allure excel 接口自动化框架
    科创人·36氪副总裁王坤:企服产品应重视使用者体验,36氪将推出中国版「魔力象限」
  • 原文地址:https://www.cnblogs.com/northern-light/p/8494711.html
Copyright © 2020-2023  润新知