咕噜咕噜ViVa 2023-12-03 18:22 采纳率: 0%
浏览 25
已结题

mysql报错1415Not allowed to return a result set from a trigger 不知如何修改

mysql报错1415Not allowed to return a result set from a trigger 不知如何修改

相关代码如下:

DELIMITER //
CREATE PROCEDURE resource_id(out next_value int)
BEGIN
DECLARE prefix VARCHAR(2);
  DECLARE max_id varchar(10);
 
  -- 获取当前表中最大的主键值
  SELECT MAX(rid) INTO max_id FROM resource;
 
  SET next_value = CAST(SUBSTRING(max_id,6, 3) AS UNSIGNED) + 1;
  -- 根据当前最大的主键值生成下一个递增值
 
  -- 返回生成的递增主键值
  SELECT next_value;
END //
DELIMITER ;

DELIMITER $$
DROP TRIGGER IF EXISTS`tri_res`$$

CREATE TRIGGER tri_res BEFORE INSERT ON RESOURCE FOR EACH ROW
BEGIN
   DECLARE NEXT INT;
   DECLARE n INT;
   DECLARE pid VARCHAR(10);
   
   SELECT LEFT(provinceid,3)  INTO pid
   FROM city,RESOURCE WHERE city.city=resource.ricty LIMIT 1;

   CALL resource_id(NEXT);
   SELECT NEXT INTO n;
   
   IF new.rtype = '餐饮美食'
   THEN
   SET new.rid = CONCAT('CY',pid, LPAD(n, 2, '0'));
   END IF;
 
END $$
DELIMITER ;


  • 写回答

15条回答 默认 最新

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月10日
  • 创建了问题 12月3日

悬赏问题

  • ¥15 Stata链式中介效应代码修改
  • ¥15 latex投稿显示click download
  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错