MySQL使用存储过程迁移用户表数据,过滤用户名相同名称不同的用户

存储过程简介

存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。它是一段预编译的SQL代码,可以被多次调用,不需要每次都重新编写SQL语句,非常适合用于大量重复性操作的场景。

在MSQL中,存储过程是一种重要的数据库对象,可以接受参数、执行特定任务、返回结果等。通过使用存储过程,可以提高数据库的执行效率、减少网络传输量、提高安全性等。

存储过程的特点如下:

  1. 预编译:存储过程在创建时就被预编译,所以执行速度快。
  2. 可重用:存储过程可以被多次调用,无需每次都重新编写SQL语句。
  3. 模块化:存储过程可以封装复杂的业务逻辑和算法,方便维护和管理。
  4. 安全性:存储过程可以提供更高级别的数据安全性,例如可以限制用户对底层数据的访问权限。
  5. 优化性能:存储过程可以减少网络传输量,提高数据库系统的性能。

MySQL使用存储过程迁移用户表数据,过滤用户名相同名称不同的用户

有以下两张用户表,使用存储过程将用户名相同,名称不同的用户合并到一张表(相同的用户名加AC)

最终效果

SQL脚本

sql 复制代码
DROP PROCEDURE IF EXISTS tsblog;
CREATE PROCEDURE tsblog ( ) 
BEGIN
 -- 定义变量
	DECLARE tusername varchar(128);
	DECLARE tname varchar(225);
	DECLARE tsname varchar(225);
	-- 定义外部游标
	DECLARE m_user_copy_cursor CURSOR FOR SELECT username,name FROM `m_user_copy`;
	
	-- 声明条件处理程序 : 当SQL语句执行抛出的状态码为02000时,将关闭游标u_cursor,并退出
	DECLARE EXIT HANDLER FOR SQLSTATE '02000' CLOSE m_user_copy_cursor;
	-- 打开游标
	OPEN m_user_copy_cursor;
	WHILE TRUE DO
		FETCH m_user_copy_cursor INTO tusername,tname;
		-- 判断用户名是否存在
		IF (select count(*) from m_user where username=tusername)>0 THEN
		  -- 判断名称是否存在
			IF (select count(*) from m_user where username=tusername and `name`=tname)<1 THEN
				-- 不存在则插入
				INSERT INTO `m_user`(`username`, `name` ) VALUES ( CONCAT('AC',tusername), tname);
			END IF;
		ELSE
			-- 用户名不存在则直接插入
			INSERT INTO `m_user`(`username`, `name` ) VALUES (tusername, tname);
		END IF;
	END WHILE;
	-- 关闭游标
	CLOSE m_user_copy_cursor;
END;

call tsblog();

另一种写法

sql 复制代码
DROP PROCEDURE IF EXISTS tsblog;
CREATE PROCEDURE tsblog ( ) 
BEGIN
 -- 定义变量
	DECLARE tusername varchar(128);
	DECLARE tname varchar(225);
	-- DECLARE tsname varchar(225);
	-- 定义外部游标
	DECLARE m_user_copy_cursor CURSOR FOR SELECT username,name FROM `m_user_copy`;
	
	-- 声明条件处理程序 : 当SQL语句执行抛出的状态码为02000时,将关闭游标u_cursor,并退出
	DECLARE EXIT HANDLER FOR SQLSTATE '02000' CLOSE m_user_copy_cursor;
	-- 打开游标
	OPEN m_user_copy_cursor;
	WHILE TRUE DO
		FETCH m_user_copy_cursor INTO tusername,tname;
		-- 判断用户名是否存在
		IF (select count(*) from m_user where username=tusername)>0 THEN
		  -- 判断名称是否存在,@符号通常用于声明局部变量或参数
			select name INTO @tsname from m_user where username=tusername;
			IF @tsname!=tname THEN
				-- 不存在则插入
				INSERT INTO `m_user`(`username`, `name` ) VALUES ( CONCAT('AC',tusername), tname);
			END IF;
		ELSE
			-- 用户名不存在则直接插入
			INSERT INTO `m_user`(`username`, `name` ) VALUES (tusername, tname);
		END IF;
	END WHILE;
	-- 关闭游标
	CLOSE m_user_copy_cursor;
END;

call tsblog();
相关推荐
ClouGence44 分钟前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库
Java水解2 小时前
Mysql查看执行计划、explain关键字详解(超详细)
后端·mysql
知其然亦知其所以然6 小时前
MySQL 社招必考题:如何优化查询过程中的数据访问?
后端·mysql·面试
DemonAvenger8 小时前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
程序新视界8 小时前
如何在MySQL中创建聚集索引?
mysql
AAA修煤气灶刘哥19 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界20 小时前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud1 天前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
RestCloud1 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术1 天前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql