0

我想在 Mysql 中编写一个函数,从给定的产品代码返回一个格式化的字符串

这是我现在需要手动进行调用以获得所需结果的示例。

SELECT p.productcategoryid from products p where (isnull(p.endeffdt) or (p.endeffdt = '0000-00-00') or (p.endeffdt > now())) and p.code='T29R66N1';

T29R66NQ 是我需要完整路径的产品代码 - 上述调用返回“38”作为类别 ID。

然后我根据上面的结果执行以下选择

SELECT name,parentid,productcategorypath FROM productcategory WHERE recid = '38';

这返回

名称->内置滚刀
parentid->7
productcategorypath=222,7,38

然后使用该结果

SELECT name,parentid,productcategorypath FROM productcategory WHERE recid = '7';

给我

名称-> 内置
parentid->222
productcategorypath=222,7

再一次,我然后做

SELECT name,parentid,productcategorypath FROM productcategory WHERE recid = '222';

这反过来又给了我

name->Kitchen & Home Appliances
parentid->0
productcategorypath=222

我停在那里,因为 parentid = 0 (它可能会继续进行更多迭代,但总是以父 id 为 0 结束),但我需要最后 3 次选择的结果给我以下字符串

Kitchen & Home Appliances > Built-In  > Built-In Hobs

我想要一个mysql函数,我可以像这样使用它

select getpath(code) from products where code='T29R66N1'

任何帮助,将不胜感激。

编辑:

我自己设法弄清楚了-这是我的功能

如果存在则删除函数 mydb.getpath;

创建函数 mydb.getpath (itemid VARCHAR(20))

返回 varchar(255)

开始

声明路径名 varchar(255);
声明 tmp_name varchar(255);
声明 tmp_parentid INT;
声明 tmp_parentid1 INT;

SELECT p.productcategoryid INTO tmp_parentid from products p where (isnull(p.endeffdt) or (p.endeffdt = '0000-00-00') or (p.endeffdt > now())) and p.code=itemid;

我的循环:循环

选择名称,parentid INTO tmp_name,tmp_parentid1 FROM productcategory WHERE recid = tmp_parentid;
SET path_name = concat_ws('>', tmp_name,path_name);
如果 tmp_parentid1!=0 那么
设置 tmp_parentid = tmp_parentid1;
迭代 myloop;
否则
离开我的循环;
万一;
结束循环;

返回路径名;

结尾;

4

1 回答 1

0
DROP FUNCTION IF EXISTS mydb.getpath;

CREATE FUNCTION mydb.getpath (itemid VARCHAR(20))

RETURNS varchar(255) 

BEGIN

DECLARE path_name varchar(255);
DECLARE tmp_name varchar(255);
DECLARE tmp_parentid INT;
DECLARE tmp_parentid1 INT;

SELECT p.productcategoryid INTO tmp_parentid from products p where (isnull(p.endeffdt) or (p.endeffdt = '0000-00-00') or (p.endeffdt > now())) and p.code=itemid;

myloop:LOOP

SELECT name,parentid INTO tmp_name,tmp_parentid1 FROM productcategory WHERE recid = tmp_parentid;
SET path_name = concat_ws(' > ', tmp_name,path_name);
IF tmp_parentid1!=0 THEN
SET tmp_parentid = tmp_parentid1;
ITERATE myloop;
ELSE
LEAVE myloop;
END IF; 
END LOOP;


RETURN path_name;


END;
于 2013-03-04T16:04:00.283 回答