DELIMITER $$ CREATE /*[DEFINER = { user | CURRENT_USER }]*/ PROCEDURE `qy_task`.`peopletask`(IN job VARCHAR(200),IN seriesid VARCHAR(200),IN classid VARCHAR(200),IN prodid VARCHAR(200),IN cycleid VARCHAR(200) ) /*LANGUAGE SQL | [NOT] DETERMINISTIC | { CONTAINS SQL | NO SQL | READS SQL DATA | MODIFIES SQL DATA } | SQL SECURITY { DEFINER | INVOKER } | COMMENT 'string'*/ BEGIN #把表围绕id创建一边然后再关联输出数据 CREATE TEMPORARY TABLE IF NOT EXISTS taskpeople SELECT gst.job_number, '' AS AREA, SUM(gst.amount) AS amount, SUM(gst.weight) AS weight, SUM(gst.area) AS AREA, SUM(qsc.weight) AS taskweight, SUM(qsc.weight)/SUM(gst.weight) AS percent FROM qy_goal_salesman_task gst INNER JOIN qy_goal_area_task gat ON gat.id =gst.area_task_id INNER JOIN qy_goal_company_task gct ON gct.id=gst.company_task_id INNER JOIN qy_goal_sale_cycle_config scc ON scc.id=gct.cycle_id INNER JOIN qy_goal_prod_config gpc ON gpc.id=gst.prod_id AND gpc.cycle_id=scc.id INNER JOIN qy_goal_prod_series_config psc ON psc.id=gpc.prod_series_id AND psc.cycle_id=scc.id INNER JOIN qy_goal_prod_classify_config pcc ON pcc.id = psc.prod_type_id AND pcc.cycle_id=scc.id INNER JOIN qy_goal_client_task_detail ctd ON gst.salesman_id=ctd.id INNER JOIN qingyuan.sys_circle sc ON sc.id=ctd.client_id INNER JOIN crm_c_duty_saler duty ON duty.c_id=sc.id INNER JOIN qyng_sys_user qsu ON qsu.id= duty.User_Id LEFT JOIN qy_sys_countydetail qsc ON qsc.proname=Pro_Name WHERE scc.id=cycleid AND qsc.CreateTime>=(SELECT start_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.CreateTime<=(SELECT end_date FROM qy_goal_sale_cycle_config WHERE id=cycleid) AND qsc.GetTime=(SELECT MAX(GetTime) FROM qy_sys_countydetail) AND gpc.id=prodid AND pcc.id=classid AND psc.id=seriesid AND gst.job_number=job GROUP BY gst.job_number; #将临时表进行数据转换 UPDATE taskpeople SET job_number= ff.User_Name FROM taskpeople e INNER JOIN qyqx.qy_staff ff ON e.job_number=ff.uid; #查出真正的表 SELECT * FROM taskpeople; #删除临时表 DROP TEMPORARY TABLE taskpeople; END$$ DELIMITER ;这段mysql存储过程哪里出现了语法错误
时间: 2024-02-11 08:07:55 浏览: 26
这段 MySQL 存储过程中出现了语法错误,具体来说是在以下这行代码:
```
GROUP BY gst.job_number;
```
末尾多了一个分号,应该改为:
```
GROUP BY gst.job_number;
```
相关问题
DELIMITER // CREATE DEFINER = CURRENT_USER FUNCTION `generate_records`(`num_records` int,`expire` datetime) RETURNS int BEGIN DECLARE i INT DEFAULT 0; DECLARE actcode VARCHAR(16); WHILE i < num_records DO SET actcode = SUBSTRING(MD5(RAND()), 1, 16); INSERT INTO `bdzs` (`actcode`, `expiretime`) VALUES (actcode, expire); SET i = i + 1; END WHILE; RETURN i; END; // DELIMITER;
这段代码是一个MySQL数据库中的函数,名为`generate_records`。它的作用是生成指定数量的随机字符串,并将其插入到`bdzs`表中,同时设置过期时间。函数接受两个参数:`num_records`表示要生成的记录数,`expire`表示过期时间。函数返回生成的记录数。
函数内部使用了一个`WHILE`循环,循环次数为`num_records`,每次循环生成一个16位的随机字符串,然后将其插入到`bdzs`表中。生成随机字符串的方式是对一个随机数取MD5哈希,并截取前16位作为字符串。最后返回生成的记录数。
需要注意的是,这段代码使用了MySQL的`DELIMITER`命令,将语句结束符号从分号(;)改为双斜线(//),以避免在函数定义中使用分号时出现语法错误。
delimiter $$ create procedure
使用delimiter进行修改定义储存过程的结束符的默认方式是将其设置为$。下面是修改定义储存过程的结束符的示例代码:
delimiter $
create procedure 存储过程名字([参数列表])
begin
sql语句集
end $
delimiter ;
使用基本语法可以定义储存过程的开始和结束标签。下面是基本语法的示例代码:
begin_label:
loop
sql语句集
end loop :end_label
另一种基本语法是直接使用分号作为储存过程的结束符。下面是使用分号作为结束符的示例代码:
create procedure 存储过程名字([参数列表])
begin
sql语句集
end;