MySQL变量使用与介绍之为查询结果增加序号列和自定义序号列

🎈个人公众号:🎈 :✨✨ 可为编程 ✨✨ 🍟🍟
🔑个人信条:🔑 知足知不足 有为有不为 为与不为皆为可为🌵
🍉本篇简介:🍉 本片详细说明了MySQL变量使用与介绍之为查询结果增加序号列和自定义序号列使用规则和注意要点,并给出具体操作实例,如有出入还望指正。

关注公众号【可为编程】回复【面试】领取2023年最新面试题!!!

首先我们先来介绍一下MySql的变量:

-- 查询所有的会话变量  如果不加globaln默认就是查会话变量
SHOW VARIABLES;
SHOW SESSION VARIABLES;
-- 查看部分会话变量
SHOW SESSION VARIABLES LIKE 'na%';
-- 查看某个指定的会话变量
SELECT @@tx_isolation;
-- 为某个会话变量赋值
SET @@tx_isolation='READ-UNCOMMITTED'


-- 自定义变量-用户变量 
-- 该变量是用户自定义的,不是由系统所定义的
-- 作用域为当前连接有效,等同于会话变量的作用域
-- 赋值操作符 = 或者 :=
-- 声明并初始化
SET @用户变量名=;
SET @用户变量名:=;
SELECT @用户变量名:=;

-- 通过SELECT INTO来设置值
SELECT 字段 INTO 用户变量名 FROMSET @name='jone'
 SET @name=100;
 SET @count=1;
--  赋值
SELECT COUNT(*) INTO @count FROM book.borrowbook
-- 查看
SELECT @count

SET @m=1;
SET @n=2;
SET @sum = @m+@n;
SELECT @sum; -- 输出3


-- 自定义变量-局部变量
-- 作用域:仅仅在定义它的BEGIN END 中有效 
-- 声明:
DECLARE 变量名 类型;
DECLARE 变量名 类型 DEFAULT 值;
-- 声明并初始化
SET @局部变量名=;
SET @局部变量名:=;
SELECT @局部变量名:=;

-- 通过SELECT INTO来设置值
SELECT 字段 INTO 局部变量名 FROM 表


用户变量	作用域为当前会话    	定义和使用的位置:会话中的任何地方          	语法:必须添加@符号,不用限定类型
局部变量	作用域为BEGIN END 中	只能在BEGIN END 中,并且为第一句话 	         一般不用加@符号 需要限定类型
关注公众号【可为编程】回复【面试】领取最新面试题!!!
-- 系统变量 说明:变量是由系统提供的,不是用户定义,属于服务器层面,
-- 查看全局系统变量
SHOW GLOBAL VARIABLES;
SELECT @@global.系统变量;

SQL三:用户表(包含字段有:用户ID[自增]、姓名、性别、民族、出生日期、身份证号),无论查询条件如何,要求查询的结果显示一个行号列(即:第一行显示1,第二行显示2,第三行显示3,依此类推)

SELECT ( @i := @i + 1 ) AS sequence, 
t_user_info.* 
FROM t_user_info,( SELECT @i := 0 ) AS it
WHERE user_sex_code = 1;

关注公众号【可为编程】回复【面试】领取2023年最新面试题!!!

SQL四:用户表(包含字段有:用户ID[自增]、姓名、性别、民族、出生日期、身份证号),用户ID是不连续性的,要求把用户ID转换成连续性的,从1开始即可

update t_user_info set user_id=user_id+100000;
update t_user_info b,
(select @rownum:=@rownum+1 as rownum, t.* from (select * from t_user_info ORDER BY user_age) t, (select @rownum:=0) tt ) temptbl 
set b.user_id = temptbl.rownum
where b.user_id=temptbl.user_id;
-- 删除连续的数据之后,执行该语句之后会从id最大值连续向下排名  否则为删除数据的最大值向后排名 无数据的话默认从1开始
ALTER TABLE t_user_info AUTO_INCREMENT = 1;


```sql
ALTER TABLE t_user_info DROP COLUMN user_id; -- 删除原来的乱序主键user_id
ALTER TABLE t_user_info ADD user_id INT ( 11 ) NOT NULL FIRST; -- 新建字段user_id
ALTER TABLE t_user_info MODIFY COLUMN user_id INT ( 11 ) NOT NULL AUTO_INCREMENT,ADD PRIMARY KEY ( user_id ); -- 设置自增和主键

欢迎感兴趣的小伙伴一起探讨学习知识,以上是个人的一些总结分享,如有错误的地方望各位留言指出,十分感谢。觉得有用的话别忘点赞、收藏、关注,手留余香! 😗 😗 😗

这里是一个真诚的***青年技术交流QQ群:761374713***,不管你是大学生、社畜、想学习变成的其他人员,欢迎大家加入我们,一起成长,一起进步,真诚的欢迎你,不管是技术,还是人生,还是学习方法。有道无术,术亦可求,有术无道,止于术。在这里插入图片描述

欢迎大家关注【可为编程】,成长,进步,编程,技术、掌握更多知识!
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

可为编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值