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();
相关推荐
sun_weitao3 小时前
Django自带admin管理系统使用
数据库·python·django
GZM8888883 小时前
多云架构下JuiceFS实现一致性与低延迟数据分发的深度解析
数据库
Jamesvalley4 小时前
【Debug】django.db.utils.OperationalError: (1040, ‘Too many connections‘)
数据库·python·django
Q_27437851094 小时前
django基于Python的智能停车管理系统
java·数据库·python·django
V+zmm101345 小时前
基于微信小程序的社区门诊管理系统php+论文源码调试讲解
数据库·微信小程序·小程序·毕业设计·php
燕双嘤7 小时前
Require:利用MySQL binlog实现闪回操作
数据库·mysql
小扬的马甲7 小时前
postgresql分区表相关问题处理
数据库·postgresql
这猪好帅8 小时前
【Redis】初识Redis
数据库·redis·缓存
网络安全-老纪8 小时前
网络安全的几种攻击方法
网络·数据库·web安全
蒜蓉大猩猩8 小时前
Node.js --- 详解MongoDB与Mongoose
数据库·后端·mongodb·node.js