位置: 编程技术 - 正文

详解PHP的Laravel框架中Eloquent对象关系映射使用(php ladp)

编辑:rootadmin

推荐整理分享详解PHP的Laravel框架中Eloquent对象关系映射使用(php ladp),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:laravel php,phpstudy laravel,php layui,php ladp,php ladp,php ladp,php laravel artisan,php laravel artisan,内容如对您有帮助,希望把文章链接给更多的朋友!

零、什么是 EloquentEloquent 是 Laravel 的 'ORM',即 'Object Relational Mapping',对象关系映射。ORM 的出现是为了帮我们把对数据库的操作变得更加地方便。

Eloquent 让一个 'Model类' 对应一张数据库表,并且在底层封装了很多 'function',可以让 Model 类非常方便地调用。来看一段如下代码:

'protected $fillable = [];' 这一行代码在这里没有任何价值,是 generator 自动生成的,在此我们不做讨论。

这个类简直再简单不过了,没有指定命名空间,没有构造函数,如果那一行没有意义的代码也不算上的话,这个文件就只有两个有实际意义的东西: 'Article' 和 'Eloquent'。没错,Eloquent 就是这么?耪ㄌ欤?恍枰?坛幸幌 Eloquent 类,就可以干 'first() find() where() orderBy()' 等非常非常多的事情,这就是面向对象的强大威力。

一、Eloquent 基本用法Eloquent 中文文档在: Eloquent 的几种常见用法的代码。

找到 id 为 2 的文章打印其标题

查找标题为“我是标题”的文章,并打印 id

查询出所有文章并循环打印出所有标题

查找 id 在 ~ 之间的所有文章并打印所有标题

查询出所有文章并循环打印出所有标题,按照 updated_at 倒序排序

基础使用要点1. 每一个继承了 Eloquent 的类都有两个 '固定用法' 'Article::find($number)' 'Article::all()',前者会得到一个带有数据库中取出来值的对象,后者会得到一个包含整个数据库的对象合集。

2. 所有的中间方法如 'where()' 'orderBy()' 等都能够同时支持 '静态' 和 '非静态链式' 两种方式调用,即 'Article::where()...' 和 'Article::....->where()'。

3. 所有的 '非固定用法' 的调用最后都需要一个操作来 '收尾',本片教程中有两个 '收尾操作':'->get()' 和 '->first()'。

二、中间操作流Builder 这个单词可以直译成构造器,但是“中间操作流”更容易理解,因为数据库操作大部分时候都是链式操作的。

中间操作流,请看代码:

这段代码的 `::where()->where()->orderBy()` 就是中间操作流。中间操作流用面向对象的方法来理解,可以总结成一句话:

创建一个对象,并不断修改它的属性,最后用一个操作来触发数据库操作。如何找到中间操作流的蛛丝马迹

中间操作流这个东西,文档里几乎没有任何有价值的信息,那么,我们该怎么找出这个玩意儿呢?很简单,使用以下代码:

然后你就会看到下面的错误:

为什么会出现错误?因为 `Article::where()` 了之后依然是 `Builder` 对象,还不是 `Article` 对象,不能直接取 `title`。

“终结者”方法

所谓 “终结者” 方法,指的是在 N 个中间操作流方法对某个 Eloquent 对象进行加工以后,触发最终的数据库查询操作,得到返回值。

`first()` `get()` `paginate()` `count()` `delete()` 是用的比较多的一些 “终结者” 方法,他们会在中间操作流的最后出现,把 SQL 打给数据库,得到返回数据,经过加工返回一个 Article 对象或者一群 Article 对象的集合。

复杂用法示例

三、模型间关系(关联)1.一对一关系

详解PHP的Laravel框架中Eloquent对象关系映射使用(php ladp)

顾名思义,这描述的是两个模型之间一对一的关系。这种关系是不需要中间表的。

假如我们有两个模型:User 和 Account,分别对应注册用户和消费者,他们是一对一的关系,那么如果我们要使用 Eloquent 提供的一对一关系方法,表结构应该是这样的:

假设我们需要在 User 模型中查询对应的 Account 表的信息,那么代码应该是这样的。 `/app/models/User.php`:

然后,当我们需要用到这种关系的时候,该如何使用呢?如下:

此时得到的 `$account` 即为 `Account` 类的一个实例。

这里最难的地方在于后面的两个 foreign_key 和 local_key 的设置,大家可以就此记住:在 User 类中,无论 hasOne 谁,第二个参数都是 `user_id`,第三个参数一般都是 `id`。由于前面的 `find()` 已经锁定了 id = ,所以这段函数对应的 SQL 为: `select * from account where user_id=`。

这段代码除了展示了一对一关系该如何使用之外,还传达了三点信息,也是我对于大家使用 Eloquent 时候的建议:

(1). 每一个 Model 中都指定表名

(2). has one account 这样的关系写成 `hasOneAccount()` 而不是简单的 `account()`

(3). 每次使用模型间关系的时候都写全参数,不要省略相应的,如果使用 belongsTo() 关系,应该这么写:

2.一对多关系

学会了前面使用一对一关系的基础方法,后面的几种关系就简单多了。

我们引入一个新的Model:Pay,付款记录。表结构应该是这样的:

User 和 Pay 具有一对多关系,换句话说就是一个 User 可以有多个 Pay,这样的话,只在 Pay 表中存在一个 `user_id` 字段即可。 `/app/models/User.php`:

然后,当我们需要用到这种关系的时候,该如何使用呢?如下:

此时得到的 `$accounts` 即为 `IlluminateDatabaseEloquentCollection` 类的一个实例。大家应该也已经注意到了,这里不是简单的 `-> hasOneAccount` 而是 `->hasManyPays()->get()`,为什么呢?因为这里是 `hasMany`,操作的是一个对象集合。

相应的 belongsTo() 的用法跟上面一对一关系一样:

3.多对多关系

多对多关系和之前的关系完全不一样,因为多对多关系可能出现很多冗余数据,用之前自带的表存不下了。

我们定义两个模型:Article 和 Tag,分别表示文章和标签,他们是多对多的关系。表结构应该是这样的:

在 Model 中使用:

需要注意的是,第三个参数是本类的 id,第四个参数是第一个参数那个类的 id。

使用跟 hasMany 一样:

这里会得到一个非常复杂的对象,可以自行 `var_dump()`。跟大家说一个诀窍,`var_dump()` 以后,用 Chrome 右键 “查看源代码”,就可以看到非常整齐的对象/数组展开了。

在这里给大家展示一个少见用法(奇技淫巧):

对,你没有看错,可以 belongsToMany 自己。其他关系

Eloquent 还提供 “远层一对多关联”、“多态关联” 和 “多态的多对多关联” 这另外三种用法,经过上面的学习,我们已经掌握了 Eloquent 模型间关系的基本概念和使用方法,剩下的几种不常用的方法就留到我们用到的时候再自己探索吧。

重要技巧:关系预载入你也许已经发现了,在一对一关系中,如果我们需要一次性查询出个 User 并带上对应的 Account 的话,那么就需要给数据库打 1 + 条 SQL,这样性能是很差的。我们可以使用一个重要的特性,关系预载入: SQL 就是这个样子的:

这样 1 + 条 SQL 就变成了 1 + 1 条,性能大增。

简单谈谈PHP中strlen 函数 strlen函数说明。intstrlen(string$string)在这篇文章,我们可以知道strlen函数是通过ZendEngine定义的。函数的定义可以在这里查看。在这里也给出函数的源码:Z

linux下为php添加iconv模块的方法 ./configure--with-mysql=/backup/mysql--with-freetype-dir--with-jpeg-dir--with-png-dir--with-zlib--with-curl--with-gd--enable-gd-native-ttf--with-apxs2=/usr/local/apache/bin/apxs--enable-sockets--with-

PHP Try-catch 语句使用技巧 PHPTry-catch语句为了进一步处理异常,我们需要使用try-catch语句----包括Try语句和至少一个的catch语句。任何调用可能抛出异常的方法的代码都应该使用try

标签: php ladp

本文链接地址:https://www.jiuchutong.com/biancheng/290348.html 转载请保留说明!

上一篇:PHP计算当前坐标3公里内4个角落的最大最小经纬度实例(php根据经纬度计算距离)

下一篇:简单谈谈PHP中strlen 函数(php中strstr)

  • 预收货款需要缴纳消费税吗?缴纳消费税的时间应该是?
  • 股东利润分配怎么做账
  • 个体工商户怎么年报
  • 营业执照备案登记流程
  • 季度企业所得税申报表怎么填写
  • 什么时候过路费是半价
  • 新公司成立第一次会议
  • 增值税进项税转出政策依据
  • 资产处置收益计入利润总额吗
  • 经营所得税投资者减除费用
  • 勾选认证有时间限制吗
  • 外单位人员报销差旅费会计分录
  • 新企业所得税法规定的企业所得税基本税率
  • 企业所得税查增值税吗
  • 增值税减免备案改备查后续管理
  • 无形资产摊销以前年度摊多了
  • 建账录入期初数据需要看哪个表
  • 厂房鉴定公司
  • 低值易耗品定义出处
  • 亏损企业所得税弥补
  • 留抵税额注销时,会计分录
  • 企业所得税计算器2023
  • 园林绿化苗木增值税抵扣税率是多少?
  • 上个月有留抵税这个月怎么结转税金
  • 堤围工程
  • 增值税专用发票怎么开
  • 应交税费未交增值税怎么计算
  • 个人所得税加计扣除有哪些项目
  • 辞退福利怎么交税
  • 个人所得税核定征收税率是多少
  • 待处理流动资产损失属于什么科目
  • 存货缺货成本如何算
  • 生产企业出口货物必须以什么为计税依据计算免抵退税额
  • 用U盘安装苹果系统
  • 在windows 10中
  • 出纳能不能兼开专票
  • 外经证预缴税款必须去外地交税吗
  • 先开票后发货怎么操作
  • PHP:pg_get_notify()的用法_PostgreSQL函数
  • 库存股属于什么项目
  • 产品设计费增值税怎么算
  • pyecharts绘制柱状图动态图
  • php读取数据库复选框数据
  • 工行退款短信图片
  • linux的nano是什么意思
  • 股权收购印花税填哪里
  • 财务报表季报利润表本月金额怎么填
  • c语言中函数的数据类型是指
  • 坏账准备的应提数
  • 什么是全面一次性奖金
  • 公司租赁房屋房产税
  • 商品损耗进项税额怎么算
  • 补提去年折旧费不需要调整所得税吗
  • 增值税计入固定资产的成本吗
  • 网上报税流程演示2019
  • 塔吊租赁和购买的区别
  • 分红冲抵往来会计分录
  • 实收资本在利润里怎么算
  • 接受捐赠收入如何计入收入
  • 分公司需要做税务报道吗
  • 新办企业是不是企业
  • 固定资产清理期末
  • mysql的操作
  • CentOS 6.5 i386 安装MySQL 5.7.18详细教程
  • 远程桌面 登录
  • windowsserver2008r2密码重置
  • 电脑主板bios设置图解
  • 回收站清空文件怎么恢复?试试这三个方法找回!
  • macbookair numbers
  • linux中sudoers
  • win10更新已经下载好了能删除吗
  • win10教育版登录
  • jquery点击切换div
  • 命令以管理员运行
  • 不用js多浏览器能用吗
  • c# 抽象类的作用
  • easyui框架的优缺点
  • shell脚本视频教程
  • python常用的内置逻辑判断函数
  • js判断网页链接是否可用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设