我试图用另一个表中的一些列来填充一个表,给出一个 id,但是我收到了这个错误:
1064 - 您的 SQL 语法有错误;检查与您的 MariaDB 服务器版本相对应的手册,以了解在 'type of products.CategoryID; 附近使用的正确语法;DECLARE t_productid 产品类型.ProductID;' 在第 4 行
我不知道如何解决它,我希望你能帮助我。
DELIMITER //
Create procedure getProducts(v_categoryid int)
BEGIN
DECLARE done INT DEFAULT FALSE;
DECLARE t_categoryid type of products.CategoryID;
DECLARE t_productid type of products.ProductID;
DECLARE t_productname type of products.ProductName;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;
DECLARE cur1 CURSOR(p_categoryid int)
FOR
SELECT CategoryID, ProductID, ProductName
FROM products
WHERE CategoryID = p_categoryid;
create table IF NOT exists curProducts(
CategoryID int(10),
ProductID int(10),
ProductName varchar(40));
truncate table curProducts;
open cur1(v_categoryid);
read_loop: LOOP
FETCH cur1 INTO t_categoryid, t_productid, t_productname;
IF done THEN
LEAVE read_loop;
END IF;
INSERT INTO curProducts VALUES (t_categoryid, t_productid, t_productname);
END LOOP;
close cur1;
select * from curProducts;
END //
DELIMITER ;