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中已建立了它们之间的 一对多关系,因此我们能够自由搭配组合
效果图例如以下:
10个Laravel4开发者必用扩展包:
http://blog.csdn.net/yimiyuangguang/article/details/39756115
Laravel Administrator 文档
http://administrator.frozennode.com/docs/field-type-relationship
Laravel4 中文帮助手冊:
Php Laravel框架 多表关系处理 之 Eloquent一对多关系处理的更多相关文章
- Struts2框架下表单数据的流向以及映射关系
本例框架很简单:默认页面为用户登录界面login.jsp,提交后由action类LoginAction.java来判断成功或失败,登录结果分别由success.jsp和failure.jsp呈现. 一 ...
- laravel框架手动删除迁移文件后再次创建报错
手动删除laravel框架数据表迁移文件后再次创建报错 如下图: 执行创建操作之后会在autoload_static.php及autoload_classmap.php这两个文件中添加迁移文件的目录. ...
- Django框架----跨表查询及添加记录
一:创建表 书籍模型: 书籍有书名和出版日期,一本书可能会有多个作者,一个作者也可以写多本书,所以作者和书籍的关系就是多对多的关联关系(many-to-many); 一本书只应该由一个出版商出 ...
- Openstack_SQLAlchemy_一对多关系表的多表插入实现
目录 目录 Openstack 与 SQLAlchemy 一个多表插入的 Demo 小结 Openstack 与 SQLAlchemy SQLAlchemy 是 Python 语言下的一款开源软件,它 ...
- Laravel5.1 模型 --一对多关系
一对多关系算是比较常用的一种关联关系了,关于一对多我们可以用 文章对应评论 来举例:一篇文章可以有多个评论,但是一个评论只属于一篇文章. 这就是一对多关系. 1 实现一对多关系 我们先来准备两个模型, ...
- 菜鸟学习Hibernate——一对多关系映射
Hibernate中的关系映射,最常见的关系映射之一就是一对多关系映射例如学生与班级的关系,一个班级对应多个学生.如图: Hibernate中如何来映射这两个的关系呢? 下面就为大家讲解一下: 1.创 ...
- Laravel 框架对于分表进行统计合并查询的思路
当对数据表进行水平分表之后,若要进行数据统计,往往需要对所有分表一起进行联合查询.在使用 Laravel 框架时,可以利用 Model 类的 setTable 方法对于多个表进行合并查询. 举个例子, ...
- laravel框架入门
本文摘自网络,个人感觉写的很不错,决定收藏一下纯属本人学习之用 本文介绍如何开始使用 Laravel. 读完本文,你将学到: 如何安装 Laravel,新建 Laravel 程序,如何连接数据库: L ...
- 关于Laravel框架
第1讲-Laravel介绍 1.1 什么是Laravel laravel是目前一个比较主流的框架,现在很多互联网的公司都在使用该框架.该框架的前身是symfony框架 Laravel的定位就是做一个简 ...
随机推荐
- (转)PHP函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
在看帝国cms的connect.php是发现第一句是error_reporting(E_ALL ^ E_NOTICE);以前也没注意过这个语句,知道是设置错误提示的,但不清楚具体怎样设置使用.下面从网 ...
- iOS之多线程开发NSThread、NSOperation、GCD
原文出处: 容芳志的博客 欢迎分享原创到伯乐头条 简介iOS有三种多线程编程的技术,分别是:(一)NSThread(二)Cocoa NSOperation(三)GCD(全称:Grand Centr ...
- 使用Eclipse创建Hibernate工程
创建一个java project项目,加入hibernate的jar包和数据库驱动包,并引入到项目.
- 各种开源协议介绍 BSD、Apache Licence、GPL V2 、GPL V3 、LGPL、MIT
现今存在的开源协议很多,而经过Open Source Initiative组织通过批准的开源协议目前有58种(http://www.opensource.org/licenses /alphabeti ...
- 『重构--改善既有代码的设计』读书笔记----Introduce Explaning Variable
有时候你会遇到一系列复杂的表达式连续运算的时候,这个时候你可能根本招架不住如此长或者是如此复杂的长函数.这个时候你可以通过引用临时变量来储存他们的结果,将这些长函数的结果分成一个个临时变量来让函数清晰 ...
- file upload download
1. 文件上传与下载 1.1 文件上传 案例: 注册表单/保存商品等相关模块! --à 注册选择头像 / 商品图片 (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 文件上传,要点: 前台: ...
- Swift互用性:与 Objective-C 的 API 交互(Swift 2.0版更新)-备
本页包含内容: 初始化 可失败初始化 访问属性 方法 id 兼容性(id Compatibility) 空值和可选值 扩展(Extensions) 闭包(Closures) 比较对象 Swift 类型 ...
- 【Maven实战】依赖的范围
在Maven中有三大模块,分别是依赖.仓库.生命周期和插件,我们接下来下来介绍下依赖,为了方便起见我们还是以案例来说: 1.首先建立一个maven项目,这里我建立一个user的项目 2.接下来我们在这 ...
- How Many Points of Intersection?
uva10790:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_prob ...
- hdu 5100 Chessboard
http://acm.hdu.edu.cn/showproblem.php?pid=5100 在比赛时没看懂题就没看,结束之后,看了解题报告才知道怎么做. 解题报告: 首先,若n<k,则棋盘连一 ...