thinkphp的多对多关系操作

先建立一个模型

01 <?php
02  class UserModel extends RelationModel{
03      protected $_link=array(
04        "group"=>array(
05            "mapping_type"=>MANY_TO_MANY,
06            "foreign_key"=>"uid",//中间表的字段
07            "relation_foreign_key"=>"gid",//中间表的字段
08            "relation_table"=>"think_user_group"
09        )
10      );
11  }
12 ?>


然后创建数据库。

分别创建三张表:think_user   think_group   think_user_group

user 表里userid、username字段

group 表里groupid、email字段

user_group 表里uid、gid字段

user_group 表里uid、gid字段都作为主键


在model中:

foreign_key 里的uid是与user表里的userid字段关联

relation_foreign_key 里的gid是与group里的groupid字段关联

然后在到控制器里创建

01 <?php
02 // 本类由系统自动生成,仅供测试用途
03 class IndexAction extends Action {
04     public function index(){
05         $db=D("user");
06         $list=$db->relation(true)->select();
07         echo "<pre>";
08         print_r($list);
09     }
10 }

可以看到你在数据表里的相关数据全部输出了!


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值