fix:仪表板复制视图时特殊情况出现重名的问题

This commit is contained in:
wangjiahao 2021-07-13 10:34:44 +08:00
parent 4151f17609
commit 15ce253f4c

View File

@ -0,0 +1,26 @@
CREATE FUNCTION `GET_CHART_VIEW_COPY_NAME`(chartId varchar(255)) RETURNS varchar(255) CHARSET utf8
READS SQL DATA
BEGIN
DECLARE chartName varchar(255);
DECLARE pid varchar(255);
DECLARE regexpInfo varchar(255);
DECLARE chartNameCount INTEGER;
select `name` ,`scene_id` into chartName, pid from chart_view where id =chartId;
/**
REGEXP进行查找qrtz_locks
1.like 'chartName%'
2.REPLACE(name,chartName,'') REGEXP '-copy\\(([0-9])+\\)$' chartName后的字符以 -copy(/d)
3.(LENGTH(REPLACE(name,chartName,''))-LENGTH(replace(REPLACE(name,chartName,''),'-',''))=1) - copy
**/
select (count(1)+1) into chartNameCount from chart_view
where (LENGTH(REPLACE(name,chartName,''))-LENGTH(replace(REPLACE(name,chartName,''),'-',''))=1)
and REPLACE(name,chartName,'') REGEXP '-copy\\(([0-9])+\\)$' and name like CONCAT(chartName,'%') and chart_view.scene_id=pid ;
RETURN concat(chartName,'-copy(',chartNameCount,')');
END