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

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

存储过程简介

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

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

存储过程的特点如下

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

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

有以下两张用户表使用存储过程将用户名相同名称不同的用户合并到一张表相同的用户名加AC
在这里插入图片描述

在这里插入图片描述
最终效果

在这里插入图片描述

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();

另一种写法

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();

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: mysql