无限级的过程
上下级会员关系通过id和pid确定。
例如:a>b>c>d>e>f>g...
就是a的下级是b,b的下级是c,c的下级是d....(有点类似传*销模式?无视掉)
需求,通过用户g查出所有的上级,则要查到f.e.d.c.b.a这些用户id
方可给这些上级发送通知。
我们最重要的是取出上级id然后就好办多了。
首先说明几个值,user_id 为用户表中的用户id,parent_id为表中用户的上级id。
示例一条基本的查询父级idsql。
select parent_id from cx_user where user_id = 10;##查询user_id为10的上级id
不说废话了,直接进入中心。
打开mysql开始写存储过程。
drop procedure if exists `getpid`;create definer = `root`@`localhost` procedure `getpid`(in `id` int)beginset @pid:=id;#id为查询的参数 即当前用户idset @pidarr:=''; #查询到的上级数组字符串recursion:while @pid!=0 do select parent_id into @pid from cx_users where user_id = @pid;#这里是你查询的sql语句 @pid是动态id if @pid=0 then #到0即结束 leave recursion; end if; if locate(@pid,@pidarr)>0 then #防止出现上下级关系混乱 leave recursion; end if; set @pidarr = concat(@pidarr,@pid); set @pidarr = concat(@pidarr,','); end while recursion;select @pidarr as pidarr;end;
存储过程执行结果,拿图吓唬吓唬你。
php端demo
$sql = call getpid(104);;$pidstr = mysql_query($sql);//换成你项目中执行mysql的函数即可 然后取出 pidarr的值到$pidstr$pidstr = rtrim($pidstr,',');//剔除最右侧多余英文逗号$pidarr = explode(',',$pidstr);//到数组//以下随意 #ncsji$@co3n#@329090*(@@()$u)@j(@(h(@jn9ncd9823n892