MySQL 使用 while 循环函数插入多行

标签 mysql database function while-loop

我正在尝试在 MySQL 数据库中插入多行。首先,我为地址创建插入函数,该函数连接到另一个仅包含格式化地址的表,因此我在另一个函数中为其插入。

然后在第三个函数中,我尝试首先为其生成虚拟地址来填充第三个表。由于某种原因,甚至第一个较低级别的函数(address_insert())由于 SQL 语法错误而无法执行,我无法弄清楚它可能是什么。有任何想法吗?

谢谢! 第一个函数:

DROP PROCEDURE IF EXISTS address_insert;
CREATE PROCEDURE address_insert()
BEGIN
DECLARE i INT DEFAULT (SELECT COUNT(*) FROM hoop.address) + 1;
DECLARE counter INT DEFAULT 0;

WHILE (counter < 5) DO 
INSERT INTO hoop.address (adr_id, address, city, country, created_at, lat, lng, updated_at, zip)
VALUES                   (i, CONCAT("Address-", i), "City", "United States", CURRENT_TIMESTAMP, RAND(35, 50), RAND(80, 120), CURRENT_TIMESTAMP, "ZIPCODE");

    SET i = i + 1;
    SET counter = counter + 1; 
END WHILE;
END;

第二个函数:

DROP PROCEDURE IF EXISTS address_shop_insert;
CREATE PROCEDURE address_shop_insert()
BEGIN
DECLARE i INT DEFAULT (SELECT COUNT(*) FROM hoop.address_shop) + 1;
DECLARE counter INT DEFAULT 0;

WHILE (counter <= SELECT COUNT(*) FROM hoop.address) DO 
INSERT INTO hoop.address_shop_insert (formatted_address, adr_id)
VALUES                               ("Formatted Address", i);

SET i = i + 1;
SET counter = counter + 1; 
END WHILE;
END;

最终功能:

DROP PROCEDURE IF EXISTS merchant_shop_insert;
CREATE PROCEDURE merchant_shop_insert()
BEGIN
address_insert()
address_shop_insert()

DECLARE i INT DEFAULT (SELECT COUNT(*) FROM hoop.merchant_shop) + 1; 
DECLARE merchant_accounts INT DEFAULT (SELECT COUNT(*) FROM hoop.merchant_account) + 1;
DECLARE shop_address_id DEFAULT (SELECT COUNT(*) FROM hoop.address_shop) - 5;
DECLARE counter INT DEFAULT 1;
DECLARE account_mod INT DEFAULT 0;
DECLARE account_id INT DEFAULT 1;

WHILE (i < merchant_accounts) DO
 IF 
    SELECT MOD(account_mod, 5) = 0
    SET account_id = account_id + 1;
 END IF;

 IF counter = 5
    SET shop_address_id = shop_address_id + 1;
    SET counter = 1;
 END IF;

  INSERT INTO hoop.merchant_shop (shop_id, contact_name, contact_phone, created_at, shop_name, status, updated_at, acc_id, shop_adr_id) 
  VALUES (i, "Strawberry Peach", "+361/789-6544", CURRENT_TIMESTAMP, CONCAT("Shop", i), 1, CURRENT_TIMESTAMP, account_id, shop_address_id)

  SET i = i + 1;
  SET account_mod = account_mod + 1;
  SET counter = counter + 1;
END WHILE;
END;

最佳答案

由于半列;结束了一个命令,所以在创建存储过程时需要定义一个具体的,否则MySQL将不知道结束命令的分隔符是什么程序声明。

DROP PROCEDURE IF EXISTS address_insert;    

-- Set the delimiter to $$
DELIMITER $$

-- Notice that every instructions IN the procedure will be ended by the regular delimiter ;
CREATE PROCEDURE address_insert()
BEGIN
    DECLARE i INT DEFAULT (SELECT COUNT(*) FROM hoop.address) + 1;
    DECLARE counter INT DEFAULT 0;

    WHILE (counter < 5) DO 
        INSERT INTO hoop.address (adr_id, address, city, country, created_at, lat, lng, updated_at, zip)
        VALUES                   (i, CONCAT("Address-", i), "City", "United States", CURRENT_TIMESTAMP, RAND(35, 50), RAND(80, 120), CURRENT_TIMESTAMP, "ZIPCODE");

        SET i = i + 1;
        SET counter = counter + 1; 
    END WHILE;
-- vv------------------------ Notice this
END$$

-- Set it back to ;
DELIMITER ;

关于MySQL 使用 while 循环函数插入多行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55220227/

相关文章:

mysql - SQL 中的 if 语句

ruby-on-rails - Rails - 当我推送到生产环境时我会丢失我的开发数据库吗?

database - 什么是 OLTP 和 OLAP。它们之间有什么区别?

Mysql LEFT 匹配前 3 个字符

Mysql - 为每个用户选择最后一行

php - 如何在 Laravel 中获取数据库列名?

c - SQLite C 用户定义函数

c - 函数分配给C中的变量

java - 在 java 中生成 SQL 字符串的好方法?

mysql - 数据抓取/仓库应用程序的数据库设计建议?