TP5中CURD那点事儿(五)

模型关联
    一般说来模型关系包括
    一对一  HAS_ONE   BELONG_TO
    一对多  HAS_MANY  BELONG_TO
    多对多  BELONGS_TO_MANY

    一对多  一用户 -> 多条评论
    Model层  User模型  Comment模型  对应两张表名
    User.php中 创建一个public comm() 方法
    public function comm()
    {
        //这是一个关系模型
        return $this->hasMany('Comment','uid','user_id');//前两个参数属于一张表,最后一个参数和本模型同表
    }
    在控制器中调用
    $user = User::get(1);
    $user -> comm;//调用属性,其实就是那个方法,就相当于user表和comment表join,返回二维数组这个人的所有评论
    //注意:调用属性返回数据记录对象,调用方法返回关联模型
    $user中指定id,则返回id为1的用户的多条评论。
    $user ->comm()//调用方法返回关系模型对象
        ->where('content','东西不错')->find();
    返回id为1 content为条件的一条评论
新增:
    $user = User::get(1);
    1、新增一条评论
    $comment = new Content();  //一个Model对应于一张评论表
    $comment -> content = '不错不错,赞一个';
    $user -> comm()->save($comment);
    2、新增多条评论 ,评论表一人评论多条
    $comment = [
        ['comment'=> '不错不错,赞一个'],
        ['comment'=> '不错不错,赞2个'],
        ['comment'=> '不错不错,赞6个'],
    ];
    $user->comm()->saveAll($comment);

关联查询:
    1、$user = User::get(1,'comm');//这里关联的是方法名,返回用户+评论
    2、带where时,$user = User::get(1);
    $user->comm()->where('is_show',1)->select();
    3、getBy 操作,$user->comm()->getByContent('动西不错');
    其他查询操作:
    User::has('comm')->select();查询有过评论的用户
    User::has('comm','>=',2)->select();评论2次以上;
    User::hasWhere('comm',['comment'=>'TP5-666'])->select();返回评论tp5-666的用户

关联更新:
    $user = User::get(1);
    $comm = $user ->comm()->getByContent('tp5-666');
    $comm->content = 'tp5-5555';
    $comm->save();
    用查询构建器的update()方法进行更新
    $user = User::get(1);
    $user -> comm() ->where('content','tp5-666')->update(['content'=>'Tp5-666']);

删除一条
    $user = User::get(1);
    comm = $user ->comm()->getByContent('Tp5-666');如果返回的comm为空,则调用delete会报错;
    comm->delete();
    删除所有的关联数据
    $user -> User::get(1);
    $user -> comm()->delete();  //删除所有的该用户的评论


一对一模型  (一人一车模型)
    建立对应user表和car表的模型,
    user.php模型中
    protected function car()
    {
        return $this->hasOne('Car','uid','userid');
    }
    Car.php暂时为空模型
    以下为控制器操作:
查询操作
    $user = User::get(1);
    $user -> email;返回user表对应用户的email字段信息
    $user -> car;//返回记录对象
    $user -> car -> brand; 返回车表相应字段,车牌号
    $user = User::get(2016,'car');//返回id为2016的用户的人、车记录信息--查两个表

新增/更新
    $user = User::get(1); //调用save()方法为更新操作
    $user = new User;     //调用save()方法为新增操作
    $user -> email = '30292510@qq.com';
    if ($user->save()){
        $user->car ->brand = '苏C23456';
        $user -> save();
        return '成功';
    }else{
        return $user->getError();
    }

删除关联
    $user - User::get(2016);
    if ($user->delete()){
        $user ->car ->delete();
    }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容