Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

大家好,又见面了,我是全栈君。

Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

        本博文主要介绍 Laravel 框架中 Eloquent  对一对多关系的处理以及在 Laravel Administrator(后台扩展包)中的应用。

        您的数据库可能是彼此相关的。比方,一篇博客文章可能有很多评论,或者一个订单与下订单的用户相关。Eloquent 使得管理和处理这些关系变得简单。Laravel 提供了四种类型的关系: –一对一一对多多对多多态关系

      一对多

一个一对多关系的样例是一篇博客文章有很多评论或者一个课程有的多次分数信息等。

我们能够像这样定义关系模型 Model:

<?php
/**
 * sobjectinfo:课程信息表 Model
 * soc_id     :主键自增
 * soc_name   :课程名
 * soc_teacher:授课老师
 **/
class SobjectInfo extends Eloquent {
    //自己定义表名(protected $table)
    protected $table = 'sobjectinfo';

    //自己定义主键(protected $primaryKey)
    protected $primaryKey = 'soc_id';

    //关闭 创建时间 与 更新时间 的自己主动维护(protected $timestamps)
    public $timestamps = false;

    /*
     * 定义一对多关系
     */
    public function Scoreinfo(){
        return $this -> hasMany('Scoreinfo','soc_id');
    }
}

?>

定义与之相应的逆向关系 Model:

<?php
/**
 * scoreinfo:分数信息表 Model
 * so_id   :主键自增
 * s_id    :学生信息表(stuinfo)主键
 * soc_id  :课程信息表(sobjectinfo)主键
 * score   :分数
 */
class ScoreInfo extends Eloquent {
       //自己定义表名(protected $table)
       protected $table = 'scoreinfo';

       //自己定义主键(protected $primaryKey)
       protected $primaryKey = 'so_id';

       //关闭 创建时间 与 更新时间 的自己主动维护(protected $timestamps)
       public $timestamps = false;

       /*
        * 分数表(ScoreInfo)与课程表(SobjectInfo)、学生信息表(StuInfo)有主外键关系
        * 而且是一对多的关系
        */
        public function StuInfo(){
            return $this -> belongsTo('StuInfo','s_id');
        }

        /*
         * 定义逆向关系指向主键表
         * */
        public function SobjectInfo(){
            return $this -> belongsTo('SobjectInfo','soc_id');
        }
} 

?

>

通过以上步骤的处理。表与表之间的一对多关系已确立,

以下将介绍在Laravel Administrato 后台中的实现 下拉列表查询、绑定等应用

<?php

return array(

    'title' => '分数信息',        //栏目名
    'single' => ' >>',            //新建描写叙述
    'model' => 'ScoreInfo',       //分数信息
    'form_width' => 960,          //左边栏目宽

    //列表
    'columns' => array(
        'so_id' => array(
            'title' => '编号',
            'select' => "so_id",
            'sort_field'=>'so_id'
        ),
        's_name'=>array(
            'title'=>'学生姓名',
            'relationship' => 'StuInfo',
            'select' => '(:table).s_name',
        ),
       'soc_name'=>array(
            'title'=>'课程名称',
            'relationship' => 'SobjectInfo',
            'select' => '(:table).soc_name',
        ),
        'score'=>array(
            'title'=>'考试分数',
            'select'=>'score'
        ),
    ),

    //筛选信息
    'filters' => array(
        'so_id' => array(
            'title'=>'编号'
        ),
        'SobjectInfo'=>array(
            'type'    => 'relationship',
            'title'   => '课程名'
            'name_field' => 'soc_name',
        ),
        'StuInfo'=>array(
            'type'  => 'relationship',
            'title' => '学生姓名',
            'name_field'  => 's_name',
        ),
        'score'=>array(
            'title'=>'考试分数',
            'type' => 'number'
        ),

    ),

    //改动、新增
    'edit_fields' => array(
        'StuInfo'=>array(
            'type'  => 'relationship',
            'title' => '学生姓名',
            'name_field'  => 's_name',
        ),
        'SobjectInfo'=>array(
            'type'    => 'relationship',
            'title'   => '课程名',
            'name_field' => 'soc_name',
        ),
        'score'=>array(
            'title'=>'考试分数',
            'type'=>'text'
        ),
    )

);

?>

以上演示样例展示的是 后台 分数信息 类。

演示样例中多次使用到 “学生姓名”、“课程名”,尽管他们存储在不同的表中,但因为我们之前在 Model中已建立了它们之间的 一对多关系,因此我们能够自由搭配组合

效果图例如以下:

Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理

10个Laravel4开发者必用扩展包:

http://blog.csdn.net/yimiyuangguang/article/details/39756115

Laravel Administrator 文档

http://administrator.frozennode.com/docs/field-type-relationship

Laravel4 中文帮助手冊:

http://pan.baidu.com/s/1jGl6cqa

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115659.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 定制office2007静默安装版

    定制office2007静默安装版现在开始打造你的office20071.    全自动安装:a)    在每个.ww里面有一个名为Config.XML的配置文件来实现的。专业增强版本位于光盘根目录下的ProPlus.ww目录下,企业版则位于Enterprise.WW目录下b)    用记事本打开目录下的Config.xml,我们只需要修改里面的相应行就可以实现免输序列号、自动输入用户名、单

    2022年7月19日
    30
  • Windows系统查看CUDA版本号

    Windows系统查看CUDA版本号问题:之前安装了CUDA,但不知道是哪个版本了?也不知道安装到哪了?解决方法:1.打开控制面板在按住Win键的情况下,按R键,呼唤运行栏。在运行框中输入control,如下图所示:2.进入NVIDIA控制面板3.查看系统信息验证:找到之前的安装目录确定了确实是10.1版本…

    2022年5月28日
    39
  • 自监督学习: 人工智能的未来

    自监督学习: 人工智能的未来目录1.什么是自监督学习?2.为什么自监督学习是AI的未来?3.1ComputerVision:[1]2015(ICCV)UnsupervisedLearningofVisualRepresentationsUsingVideos[2]2015(ICCV)UnsupervisedVisualRepresentationLearningbyContextPrediction[3]2016(ECCV)Unsupervisedlearni

    2022年9月14日
    6
  • python猪脸识别_京东JDD猪脸识别比赛「建议收藏」

    python猪脸识别_京东JDD猪脸识别比赛「建议收藏」pig_face_recognition京东JDD猪脸识别比赛pytorch-baseline1.运行环境TeslaK20c集群单节点双卡RedHat4.4.7-3Python2.7.13cuda8.0cudnn5.0pytorch0.3.02.从视频中截取出猪用yolo-9000算法,人工打label后,对ffmpeg提取出的视频帧进行猪的目标检测,框出猪的主体部分,为后续…

    2022年6月21日
    37
  • STemWin学习:关于窗口消息的基础知识

    STemWin学习:关于窗口消息的基础知识刚开始接触emWin,记录一下我自己感悟的心得。首先从GUIBuilder小工具创建的窗口文件讲解。//USERSTART(Optionallyinsertadditionalstaticdata)#defineBUTTON_SIZE_X20#defineBUTTON_SIZE_Y20#defineBUTTON_START_X55#define…

    2025年6月29日
    2
  • API Testing 11 – SOAP和REST API区别

    API Testing 11 – SOAP和REST API区别设计一个Webservice或API依靠下面两个通用的实现:SOAP–SimpleObjectAccessProtocolREST–RepresentationalStateTransferProtocol采用哪种实现方式创建一个Webservice或API,取决于项目或系统的需求。我们来探讨一下SOAP和REST的区别。当下RESTWebservice比较抢手。SOAP和REST的基本区别如下:SOAP是协议,REST是架构风格SOAPWebServices

    2022年7月14日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号