Mysql 循环插入数据

CREATE TABLE test_t(

role_id INT ,

menu_id INT ,

company_id INT

)

第一种:

INSERT INTO test_t(role_id,menu_id,company_id) SELECT 1000,id,1 FROM test WHERE product_id IS NULL

第二种:

DELIMITER //

CREATE PROCEDURE proc()

BEGIN

DECLARE role INT;

DECLARE menu INT;

DECLARE company INT;

DECLARE done INT DEFAULT FALSE;

DECLARE cur CURSOR FOR

SELECT 1,id,1 FROM test WHERE product_id IS NULL;

-- 将结束标志绑定到游标

DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;

OPEN cur;

read_loop: LOOP

FETCH cur INTO role,menu,company;

IF done THEN

LEAVE read_loop;

END IF;

INSERT INTO test_t(role_id,menu_id,company_id) VALUES(role,menu,company);

END LOOP;

-- 关闭游标

CLOSE cur;

END //

CALL proc()

相关推荐
heze098 小时前
sqli-labs-Less-18自动化注入方法
mysql·网络安全·自动化
oh LAN14 小时前
提升性能:数据库与 Druid 连接池优化指南
数据库·mysql
Maggie_ssss_supp15 小时前
Linux-MySQL权限管理
linux·运维·mysql
独自破碎E16 小时前
MySQL中如何进行SQL调优?
数据库·sql·mysql
林九生17 小时前
【MySQL/PostgreSQL】MySQL 到 PostgreSQL 数据迁移:Docker + pgloader
mysql·docker·postgresql
heze0918 小时前
sqli-labs-Less-19自动化注入方法
mysql·网络安全·自动化
霖霖总总19 小时前
[小技巧37]解构 my.cnf:[client] 与 [mysql] 背后的加载逻辑与优先级
运维·mysql
liux352819 小时前
MySQL日志系统全面解析:从基础到高级管理(六)
数据库·mysql·oracle
Maggie_ssss_supp20 小时前
Linux-MySQL日志管理
数据库·mysql
熬夜敲代码的小N20 小时前
MySQL数据可视化实战:从SQL雕琢到图表绽放
sql·mysql·信息可视化