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();
相关推荐
ejinxian几秒前
MySQL/Kafka数据集成同步,增量同步及全量同步
数据库·mysql·kafka
未来之窗软件服务5 分钟前
数据库优化提速(一)之进销存库存管理—仙盟创梦IDE
数据库·sql·数据库调优
Mapmost1 小时前
信创浪潮下的GIS技术变革:从自主可控到生态繁荣
数据库
foundbug9991 小时前
Node.js导入MongoDB具体操作
数据库·mongodb·node.js
天天进步20151 小时前
Node.js中的Prisma应用:现代数据库开发的最佳实践
数据库·node.js·数据库开发
@_码农2 小时前
【MySQL的卸载】
mysql
hui函数2 小时前
Flask高效数据库操作指南
数据库·python·flask
Momentary_SixthSense2 小时前
RESP协议
java·开发语言·javascript·redis·后端·python·mysql
MacroZheng2 小时前
横空出世!一款开源的数据同步工具,稳定又高效,好用到爆!
java·后端·mysql