Laravel五大功能之Eloquent关系模式
Eloquent是Laravel的原始ActiveRecord是实现的,建立在Laravel的Fluent Query Builder之上的,所以Eloquent类和Fluent类是一样的,能实现复杂的SQL语句和非常直观表达出的表与表之间的关系
ActiveRecord也属于ORM层,由Rails最早提出,遵循标准的ORM模型:表映射到记录,记录映射到对象,字段映射到对象属性。配合遵循的命名和配置惯例,能够很大程度的快速实现模型的操作,而且简洁易懂。
ActiveRecord的主要思想是:
1. 每一个数据库表对应创建一个类,类的每一个对象实例对应于数据库中表的一行记录;通常表的每个字段在类中都有相应的Field;
2. ActiveRecord同时负责把自己持久化,在ActiveRecord中封装了对数据库的访问,即CURD;;
3. ActiveRecord是一种领域模型(Domain Model),封装了部分业务逻辑;
现在我们讲讲ActiveRecord在Laravel中的应用
关于Eloquent的方法及其操作可以具体的可以看文档,在这里我们主要讲解表的关系
一对一的关系(one-to-one relationship)
关系数据库中两个表之间的一种关系,该关系中第一个表中的单个行只可以与第二个表中的一个行相关,且第二个表中的一个行也只可以与第一个表中的一个行相关。
假如我们有一张user表和一张passport表是一对一的关系
首先让我们来表达出这样子的关系在我们的User类(用于操作user表)中
class User extends Eloquent
{
public function passport()
{
return $this->has_one('Passport');//描述了在每一个用户都有对应的passport
}
}
如果我们想得到用户id为1的passport,我们应该怎么做呢?
$user = User::find();//实例化User表
if(is_null($user))
{
echo "No User found!";
return;
}
if($user->passport)
{
//$user->passport将会得到$user对应的Passport实例,再来获取number
echo "The user's passport number is".$user->passport->number;
}
再来看看我们的Passport类(用于操作passport表)中,有一个外键user_id
class Passport extends Eloquent
{
public function user()
{
return $this->belongs_to('User');//这样我们就表达出了user_id这个外键对应的是user表
}
}
如果我们要通过一个passport来得到它所指向的用户的名字
$passport = Passport::find();
echo $passport->user->name;
就是这么简单!laravel就是这么方便!如果你用过其他的PHP框架的话,一定能感觉到的!
一对多关系(one-to-many relationships)
关系数据库中两个表之间的一种关系,该关系中第一个表中的单个行可以与第二个表中的一个或多个行相关,但第二个表中的一个行只可以与第一个表中的一个行相关。
假如我们有一张运动小组表,有运动员表许多的运动员,每一个运动员都属于某一个小组
表team
class Team extends Eloquent
{
public function palyers()
{
return $this->has_many(‘Player’);
}
}
表players
class Player extends Eloquent
{
public function team()
{
return $this->belongs_to('Team');
}
}
接着咱们来看看改如何来得到一个小组的所有成员呢?
$team = Team::find();
$palyers = $team->palyers()->get();
foreach($players as $player)
{
echo '$play->name is on team $team->name';
}
多对多关系(many-to-many relationships)
关系数据库中两个表之间的一种关系, 该关系中第一个表中的一个行可以与第二个表中的一个或多个行相关。第二个表中的一个行也可以与第一个表中的一个或多个行相关。要表示多对多关系,您必须创建第三个表,该表通常称为联接表,它将多对多关系划分为两个一对多关系。
假如有这样子三张表
每个学生都可以任意的挑选课程,每门课程也可以有任意的学生来挑选
现在来看看我们怎么定义Model
Student表的模型
class Student extends Eloquent
{
public function courses()
{
return $this->has_many_and_belongs_to('Course');
}
}
Course表的模型
class Course extends Eloquent
{
public function students()
{
return $this->has_many_and_belongs_to('Student');
}
}
让我们来使用我们的模型,通过找到id为1的学生选修的课程
$student = Student::find(); if(is_null($student))
{
echo "没有此学生";
exit;
} if(!$student->courses)
{
echo "学生: $student->name 没有选修任何课程。";
exit;
}
else
{
foreach($student->courses as $course)
{
echo "学生:$student->name 选修的课程有:$course->name";
}
}
接着我们来通过课程找出他所对应的所有学生
$course = Course::find();
if(is_null($course))
{
echo "没有此课程";
exit;
}
if($course->students)
{
foreach($course->students as $student)
{
echo "该课程:$course->name选修的学生有:$student->name";
}
}
else
{
echo "课程暂时没有学生选修!";
exit;
}
如果我们想给一门没有被选修的课程添加信息应该怎么做呢?
$course = Course::find();
if(is_null($course))
{
echo "该课程不存在!"
exit;
}
$new_student = array(
'name' => '沖田杏梨';
); $course->students()->insert($new_student);
Laravel五大功能之Eloquent关系模式的更多相关文章
- E-R图向关系模式的转换
转自: http://hi.baidu.com/qicaiqinxian/blog/item/a8bb0bdf31ae081b63279887.html E-R图向关系模型转换时犯糊涂了,找到下面这篇 ...
- 如何将ER图转换成关系模式集
在ER图中,主要是实体类型和联系类型. 1.实体类型的转换 (“——”表示对应关系) 实体类型——关系模式 实体的属性——关系模式的属性 实体标识符——关系模式的键 2.联系的转换 一元联系较简单,三 ...
- ER 和 数据库关系模式
http://lianghuanyue123.blog.163.com/blog/static/130423244201162011850600/ 我们眼下所接触的数据库基本上是关系数据库,关系数据库 ...
- ER图,以及转化成关系模式
1.找出条件中的实体(矩形),属性(椭圆),关系(菱形)关系分为1:1,1:N,M:N,列出ER图 2. -1:1联系的转换方法 -两个实体分别转化为一个关系模式,属性即是本来的属性 -关系可以与任意 ...
- 关系、关系模式、关系模型blablabla...
好久没碰<数据库系统概论>了,最近翻了翻发现好多专业名词都忘记了, 现在有空特地记录下. 名词解释 数据:数据就是数据库中存储的基本数据,比如学生的学号.学生的班级数据库:存放数据的仓库数 ...
- UML类图关系模式(C++代码说明)
在UML类图中的关系模式主要有以下几种: 泛化(Generalization), 实现(Realization), 关联(Association), 聚合(Aggregation), 依赖(Depe ...
- 【例3】设有关系模式R(A, B, C, D, E)与它的函数依赖集F={A→BC, CD→E, B→D, E→A},求R的所有候选键。 解题思路:
通过分析F发现,其所有的属性A.B.C.D.E都是LR类属性,没有L类.R类.N类属性. 因此,先从这些属性中依次取出一个属性,分别求它们的闭包:=ABCDE,=BD,=C,=D, =ABCDE.由于 ...
- 关系模式范式分解教程 3NF与BCNF口诀
https://blog.csdn.net/sumaliqinghua/article/details/86246762 [通俗易懂]关系模式范式分解教程 3NF与BCNF口诀!小白也能看懂原创置顶 ...
- Laravel 5 基础(十一)- Eloquent 关系
一个用户可能有多个文章,一个文章是某个用户书写的,这就是关系.同样文章中可能包含多个 TAG,而一个 TAG 可能关联多个文章. 在项目中,我们已经有了 User.php,也就是用户模型,查看一下,相 ...
随机推荐
- KMP算法-Java实现
目的: 为了解决字符串模式匹配 历程: 朴素模式匹配:逐次进行比较 KMP算法:利用匹配失败得到的信息,来最大限度的移动模式串,以此来减少比较次数提高性能 概念: m:是目标串长度 n:是模式串长度 ...
- 【转】窗口之间的主从关系与Z-Order
原文链接:http://www.cnblogs.com/dhatbj/p/3288152.html 说明:这是本人2008年写的一篇旧文,从未公开发表过.其中除了一小段描述Window Mobile平 ...
- 从零开始学 Java - 数据库连接池的选择 Druid
我先说说数据库连接 数据库大家都不陌生,从名字就能看出来它是「存放数据的仓库」,那我们怎么去「仓库」取东西呢?当然需要钥匙啦!这就是我们的数据库用户名.密码了,然后我们就可以打开门去任意的存取东西了. ...
- 从零开始学 Java - Spring 一主多从、多主多从 数据库配置
待会苹果要开发布会 我写完这篇文章就准备去看发布会了,因为我买了好几包瓜子和啤酒.由于苹果的保密做的越来越差劲,该曝光的信息差不多全部曝光了,我们这种熬夜看发布会的只不过是让这些信息更加真实,或者说是 ...
- html 输入框 只能输入数字 只能输入字母数字组合
JS判断只能是数字和小数点 1.文本框只能输入数字代码(小数点也不能输入) <input onkeyup="this.value=this.value.replace(/\D/g,'' ...
- JavaScript变换表格边框颜色
效果查看:http://hovertree.com/texiao/js/2.htm 代码如下,保存到HTML文件也可以查看效果: <html> <head> <meta ...
- jQuery基础知识总结
1. jQuery基本概念介绍 1.1 什么是jQuery 一个javascript库,把常用方法写到一个js文件中,需要的时候直接调用即可 学习jQuery就是学习一些方法 ...
- 来自沪江、滴滴、蘑菇街架构师的 Docker 实践分享
架构师小组交流会是由国内知名公司架构师参与的技术交流会,每期选择一个时下最热门的技术话题进行实践经验分享. Docker 作为当前最具颠覆性的开源技术之一,其轻量虚拟化.可移植性是 CI/CD.Dev ...
- 几个常用的adb命令
adb全程为Android Debug Bridge,字面意思就是安卓调试桥接.就是android系统提供的一套 工具帮我们建议一个连接android设备的通道,然后在电脑上发送一些指令,完成工作. ...
- CoreData数据库浅析
Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将OC对象转化成数据,保存在SQLite数据库文件中,也能够将保存在数据库中的数据还原成OC对象.在此数 ...