Toggle navigation
菜菜小站
菜菜小站
前端开发
前端开发
前端基础
bootstrap
JavaScript
后端开发
后端开发
php开发
laravel
数据库
编辑器
git
服务器
服务器
https
cos云存储
ubuntu
homestead
微信开发
微信开发
微信小程序
python开发
python开发
python基础
关于
laravel 无限极分类
作者:
菜菜子
|
时间:2018-09-01 21:17:00 |
分类:
后端开发
,
laravel
|
访问: 1,113 次|
评论:
0 评论
需要实现一个无限极分销的功能,此外这个分销还存在一个断链的情况 举例: 下面的parent_user_id表示上级用户id,grade表示当前用户等级,共四级(0普通会员 1铜牌会员 2银牌会员 3金牌会员) * 情况1: | id | parent_user_id | grade | | -- | ---- | --- | | 1 | | 0 | | 2 | 1 | 0 | | 3 | 2 | 0 | | 4 | 3 | 0 | 那么现在id为1的这个用户的所有下线就是id为2,3,4的用户(即如果查询用户为普通用户,那么所有下线用户应该都为普通会员,此时下线会员等级与自己相同或者更低) * 情况2: | id | parent_user_id | grade | | -- | ---- | --- | | 1 | | 0 | | 2 | 1 | 0 | | 3 | 2 | 1 | | 4 | 3 | 0 | 那么现在id为1的这个用户的所有下线就是id为2的用户(即如果查询用户**为普通用户**,那么所有下线用户应该都为普通会员,此时下线会员等级与自己相同或者更低) * 情况3: | id | parent_user_id | grade | | -- | ---- | --- | | 1 | | 1 | | 2 | 1 | 0 | | 3 | 2 | 1 | | 4 | 3 | 0 | 那么现在id为1的这个用户的所有下线就是id为2的用户(即如果查询用户**不为普通用户**,那么所有下线用户应该都为比自己级别低的用户,不能与查询用户级别相等) * 情况4: | id | parent_user_id | grade | | -- | ---- | --- | | 1 | | 2 | | 2 | 1 | 0 | | 3 | 2 | 1 | | 4 | 3 | 0 | 那么现在id为1的这个用户的所有下线就是id为2,3,4的用户(即如果查询用户**不为普通用户**,那么所有下线用户应该都为比自己级别低的用户,不能与查询用户级别相等) 简单来说就是如果下线用户升级以后,这条链路就断开了。 ### 实现方法 #### 第一步建表: ```php increments('id'); $table->string('nickname')->comment('昵称'); $table->string('phone')->unique()->comment('手机号'); $table->string('password'); $table->string('parent_user_id')->nullable()->comment('推荐人id'); $table->enum('grade', [0,1,2,3]])->default(0)->comment('会员等级'); $table->string('recommend_no')->unique()->comment('推荐码'); $table->rememberToken(); $table->timestamps(); }); } /** * Reverse the migrations. * * @return void */ public function down() { Schema::dropIfExists('users'); } } ``` ### 模型 ```php '普通会员', self::GRADE_TWO => '铜牌会员', self::GRADE_THREE => '银牌会员', self::GRADE_FOUR => '金牌会员', ]; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'nickname', 'phone', 'password', 'recommend_no', 'parent_user_id' ]; /** * The attributes that should be hidden for arrays. * * @var array */ protected $hidden = [ 'password', 'remember_token', ]; public function getJWTIdentifier() { return $this->getKey(); } public function getJWTCustomClaims() { return []; } public function getQrcodeAddressAttribute($value) { return getAttributes($value); } /**上线start*************************************************************************/ //上级推荐人(不论等级) public function parent_user() { return $this->belongsTo(get_class($this)); } //上级推荐人(论等级) public function parentUserUp() { $parent_user = $this->parent_user;//上级用户 // dd($parent_user->grade); if (!blank($parent_user)) { if ($this->grade == 0) { //如果被查询用户的是普通用户,那就直接返回父级用户 return $parent_user; } else { //如果查询的用户不是普通用户,那就只查比自己等级高的父级 if ($parent_user->grade > $this->grade) { //父级用户比自己级别大才返回该父级用户 return $parent_user; } else { //否则返回null return null; } } } else { return null; } } //所有上级推荐人(论等级) //如果用户是普通会员就不断的上查,如该用户是普通会员,上级用户也是普通会员,上上级用户也是普通会员,上上上级用户也是普通会员,那么这些上级用户都能拿到返现 //如果用户不是普通会员,如该用户是铜牌会员,那就查上级用户是银牌,如果上级用户是银牌,那就查上上级用户是银牌的,依次类推... public function allParentUserUp() { $result = new Collection; $parent = $this->parentUserUp(); // dd($parent); if (!blank($parent)) { $result->push($parent); dump($parent); $all_parent_users = $parent->allParentUserUp(); if (!blank($all_parent_users)) { foreach ($all_parent_users as $subChild) { $result->push($subChild); } } } return $result; } /**end*************************************************************************/ /**start*************************************************************************/ //所有比自己等级低的通过自己推荐码进来的用户(当自己为普通会员时除外) public function children_down_users() { $all_child = $this->hasMany(get_class($this), 'parent_user_id'); if ($this->grade == 0) { return $all_child->where('grade', '=', $this->grade); } else { return $all_child->where('grade', '<', $this->grade); } } //该用户的所有下线用户集合 public function all_children_down_users() { $result = new Collection; $children = $this->children_down_users; foreach ($children as $child) { $result->push($child); $childResult = $child->all_children_down_users(); foreach ($childResult as $subChild) { $result->push($subChild); } } return $result; } /**end*************************************************************************/ } ``` ### 使用方法 查找比这个用户低的所有下线子用户 ```php auth()->user()->all_children_down_users() ``` 查找这个用户的所有上线用户 ```php auth()->user()->allParentUserUp() ``` ### helpful 集合分页方法: https://www.cc430.cn/index.php/archives/635/ 参考: https://laravel-china.org/articles/12466/unlimited-classification
标签:
无限极分类
,
分销
还不快抢沙发
添加新评论
昵称(必填)
邮箱(必填)
网站(选填)
内容(必填)
提交评论
最新文章
ubuntu自动化安装php文件
laravel 操作redis
laravel-admin静态资源加速
laravel-admin1.6版本表单tag bug修复方法
laravel根据另外一列的值赋予grid某一列editable()
laravel-admin数据来源非数据表信息
laravel判定多对多关系是否存在
最新回复
森木志: 对的 用的就是这个版本 我看plugin.php的...
菜菜子: 插件版本呢?应该用https://github.com...
森木志: 忘记说了,typecho版本是1.2.1,php版本是...
森木志: 遇到灵异事件了,设置是没问题的,按道理来说上传成功后的...
局外人: 下载失败了,大佬帮忙看看是什么原因呢?
青丝: 7355763
菜菜子: 我好像沒有做這個提示,方便加微信吧,我看看什麼問題
青丝: 对的,提示需要8.0PHP
菜菜子: 你版本不對吧
菜菜子: 你是typecho1.2?用的是https://git...
标签
前端框架
bootstrap
laravel5
laravel-admin
laravel
微信小程序
gd库
git
wamp配置
https
表单
cos小工具
微信支付
ajax
cos
cos插件
vue
nginx
homestead
linux
ubuntu
swoole
typecho
编辑器
破解
数组
jwt
sql语言
腾讯云
邮件发送
websocket
队列
微信公众号
分页
日志
elasticsearch
wnmp
vagrant
无限极分类
分销
集合
supervisor
部署
grid
redis
python
标签
刷新
加密处理
验证码
悬浮框
权限控制
markdown
shell
mysql
测试
ui
任务调度
定时任务
deployer
gogs
反向代理
ftp
归档
2019年01月
2018年12月
2018年11月
2018年10月
2018年09月
2018年08月
2018年07月
2018年06月
2018年05月
2018年04月
2018年03月
2017年09月
2017年06月
2017年05月
2017年04月
2017年03月
2017年02月
2017年01月
2016年12月
2016年11月
友情链接
空
//