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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • CC2530: ZigBee协议栈实践例程(一)

    CC2530: ZigBee协议栈实践例程(一)1.ZigBee版本      ZigBee是ZigBee联盟建立的技术标准。第一个ZigBee协议栈规范于2004年发布,称为ZigBee2004或者ZigBee1.0;第二个ZigBee协议栈规范于2006年发布,称为ZigBee2006;第三个ZigBee协议栈规范于2007年发布,称为ZigBee2007;然后呢?现在是2018年了。。。2.Z-Stack版本    …

  • 配置zabbix时启动失败解决办法

    配置zabbix时启动失败解决办法一开始按照这篇博客来配置zabbixhttps://blog.csdn.net/rujianxuezha/article/details/79842998启动zabbix时出现以下提示[root@www~]#systemctlstartzabbix-serverJobforzabbix-server.servicefailedbecauseaconfiguredresourc…

  • [4G+5G专题-137]: 终端 – 射频前端(滤波器、功率放大器)详解

    作者主页(文火冰糖的硅基工坊):文火冰糖(王文兵)的博客_文火冰糖的硅基工坊_CSDN博客本文网址:目录第1章射频前端FEM概述第2章滤波器2.1滤波概述2.2SAW:成熟且仍在发展2.3高性能BAW2.4器件市场分析第3章功率放大器3.1功率放大器概述3.2市场格局第1章射频前端FEM概述射频前端聚焦的是调制后的高频(射频)电磁波的功率和带宽。带宽的控制是由滤波器完成的。功率的控制是由PA完成的第2章…

  • excel差异显著性分析的结果怎么看_excel三组数据的显著性差异

    excel差异显著性分析的结果怎么看_excel三组数据的显著性差异如何利用excel进行数据差异显著性分析利用excel进行数据差异显著性分析的步骤:工具原料:excel2013版本;1.打开excel,添加“数据分析”模块;结果如图;添加“数据分析”模块步骤:①单击左上角“文件”选项;②在弹框中,选择“选项”;③再选择“加载项”,选择”分析工具库“;④点击”转到(G)”,在弹出的”加载宏“,界面里勾选”分析工具库“,点击确定即可;⑤添加“数据分析”模块成功…

    2022年10月26日
  • 25种提高网页加载速度的方法和技巧

    25种提高网页加载速度的方法和技巧

  • &0xff的原因

    &0xff的原因&0xff的目的

发表回复

您的电子邮箱地址不会被公开。

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