首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

TP5 关联模型使用(嵌套关联、动态排序以及隐藏字段

在数据库设计中,常常会有如下这种关联模型,分类表中一条分类对应多个商品表中的商品 如果要获得分类表中每条分类 以及 对应的商品的信息,则需要先查询分类表中的数据,然后根据结果遍历查询商品表,最后把数据拼接在一起...TP5中关联模型可以解决这一问题 普通关联 先创建分类表模型 /application/common/model/Category.php 以及商品表模型 /application/common/...(){ return $this->hasMany('Goods','category_id','id'); } } 接着就可以使用关联模型查询数据 public function list(...public function index() { return Category::with('product,product.property')->where('id',1)->find(); } 在调用关联模型查询数据时...理论上可以在关联的两张表中建立关联关系,例如用户表User 和用户信息表 Profile 是一对一的关系,假设在Profile表中user_id字段指向User表的id字段,那么在User表中可以建立外键

1.3K20
您找到你想要的搜索结果了吗?
是的
没有找到

Django 2.1.7 模型关联

但是没有讲到两张表的关联查询的实现,这个在模型里面该怎么处理呢?...在进行关联查询之前,首先要了解一下模型之间的关联关系,以及相应的操作。...也可以不设置一个外键,直接就单纯一个int字段来记录ServerInfo类的id也是可以的。 多对多关系 在前面篇章中,并没有设计关于多对多的关联模型,那么现在可以设计一个。...通过模型类执行关联查询 由多模型类条件查询一模型类数据: 语法如下: 关联模型类名小写__属性名__条件运算符=值 如果没有"__运算符"部分,表示等于,结果和sql中的inner join相同。...: 语法如下: 一模型关联属性名__一模型类属性名__条件运算符=值 例:查询服务器为“测试服务器”的所有中间件信息。

1.5K20

YII关联字段并带搜索排序功能

2、操作步骤   背景:这里针对GII自动生成的CURL中,增加关联字段。   ...需求:A表中有一个字段pt_id关联B表;现在需要在基于A表GII生成的CURL的基础上,增加A表关联B表字段的name值,并且带有搜索排序功能。   ...2.1、step1在A model中添加一个方法 1 //意思即获取Pt的数据 2 public function getPt() //get** get后面任意 3 { 4 //模型名...、step2在A search 中添加需要关联字段变量 1 public $name; //可以关联显示多个字段 2 public $*****; //例子    2.3、修改A search中的...3、小结   这里仅仅只是一个小小的例子,通过这个例子可以知道yii添加关联字段的方法,那么你就可以根据现有的知识更改出更多的花样出来。。。。

91120

phpcms文章内容页如何自定义url

希望phpcms跟WordPress一样,能够在文章发布页面自定义url,从而提高SEO优化吗?...phpcms V9版本默认是不支持自定义网址的,不过只要跟我一起稍微做下改动即可实现自定义url,甚至超过WordPress的固定连接功能。...添加字段 内容-模型管理-选择你要修改的模型,一般是文章模型,然后是字段管理,添加字段 作为主表字段,选择 是,非常重要,否则在批量生成url中会无法生成自定义字段 字段名为prefix 不建议修改,因为要跟后面的代码关联起来...字段别名为 html文件名 ,这个随意,好记即可 值唯一选 是,你不希望2篇文章的url是同一个吧,这样就会覆盖上一篇文章 其他保持默认即可 修改网址生成文件 打开/phpcms/modules/content...创建或编辑内容时会生成HTML 内容管理里下面有个“批量生成HTML” 发布管理的“批量更新内容”他又包含了先择模型生成和不选择模型生成 享受战果 后台-扩展-URL规则管理中,URL规则用 {$id}

7K20

TP6.0 一对一模型关联 belongsTo 相对关联(反向关联

创建数据表 ---- 一对一反向关联使用率很高 附表关联主表称为反向关联,又称为相对关联(tp官方手册这样叫) -- 分类表 CREATE TABLE `category` ( `id` int(10...文章模型定义一对一相对关联方法 ---- public function category() { /** * belongsTo('关联模型', '当前模型外键', '关联模型主键'); * * 第一个参数...* app\model\Category 关联模型类名(分类表模型) * * 第二个参数 * category_id 外键字段,默认的外键名规则是关联模型名+_id(文章表外键字段) * * 第三个参数...* id 关联模型主键,默认是关联模型的 $pk 值(分类表主键字段) */ return $this->belongsTo(Category::class, 'category_id', 'id')...; } 3. belongsTo() 也支持额外的方法 同 hasOne() ---- public function category() { /** * belongsTo('关联模型', '当前模型外键

97530

Laravel Eloquent 模型关联关系(下)

在前面两篇教程中,学院君陆续给大家介绍了 Eloquent 模型类支持的七种关联关系,通过底层提供的关联方法,我们可以快速实现模型间的关联,并且进行关联查询。...如果要统计其它关联模型结果数量字段,可以依次类推,对应字段都是 {relation}_count 结构。...一对多关联记录插入 新增关联模型的时候,可以在父模型上调用相应方法直接插入记录到数据库,这样做的好处是不需要指定关联模型与父模型的外键关联字段值,Eloquent 底层会自动判断并设置。...如果是要更新新创建的模型实例所属模型(父模型)的外键字段,比如以 posts 表为例,新增的记录想要更新 user_id 字段,可以这么实现: $user = User::findOrFail(1);...Eloquent 提供了这种同步机制帮助我们更新子模型时触发父模型的更新时间 updated_at 字段值更新,要让该机制生效,需要在子模型中配置 $touches 属性: // 要触发更新的父级关联关系

19.5K30

Laravel 模型关联基础教程详解

当涉及到查询模型时,我们如何充分利用模型关联的功能? Laravel 的模型关联可能会让人糊涂。...这种类型的关联意味着一个类型A的模型可以链接到多个类型B的模型。但是类型B的模型只属于一个类型A的模型。 例如,User 模型和 Invoice 模型之间的关联是一对多关联。...这种类型的关联意味着类型A的一个模型可以链接到类型B的多个模型,反之亦然。 例如,Invoice 模型和 Product 模型之间的关联将是多对多关联。...举个例子,假设连接的表有 created_at 字段,我们就可以使用 pivot 来获取 created_at 字段。 <?...php $invoice = \App\Invoice::find(1); // 获取 product 的 `created_at` 字段 foreach($invoice- products as $

5.5K31

Django 2.1.7 模型类 - 字段类型

本篇章开始将继续看看模型类还可以设置哪些字段类型 参考文献 https://docs.djangoproject.com/zh-hans/2.1/ref/models/fields/ 前面篇章设置好的两个模型类...,还有很多字段类型没有在这两个模型体现出现。...在官方文档中,关于字段类型的描述非常多,如下: 模型字段的定义属性 django会为表创建自动增长的主键列,每个模型只能有一个主键列,如果使用选项设置某属性为主键列后django不会再创建自动增长的主键列...primary_key:若为True,则该字段会成为模型的主键字段,默认值是False,一般作为AutoField的选项使用。...编写模型类演示 有了上面关于字段类型的相关说明,下面来丰富一下我这边编写的模型字段属性,如下: class ServerInfo(models.Model): server_hostname

1.7K30

Django 2.1.7 模型关联

但是没有讲到两张表的关联查询的实现,这个在模型里面该怎么处理呢?...在进行关联查询之前,首先要了解一下模型之间的关联关系,以及相应的操作。...也可以不设置一个外键,直接就单纯一个int字段来记录ServerInfo类的id也是可以的。 多对多关系 在前面篇章中,并没有设计关于多对多的关联模型,那么现在可以设计一个。...通过模型类执行关联查询 由多模型类条件查询一模型类数据: 语法如下: 关联模型类名小写__属性名__条件运算符=值  如果没有"__运算符"部分,表示等于,结果和sql中的inner join相同。...: 语法如下: 一模型关联属性名__一模型类属性名__条件运算符=值 例:查询服务器为“测试服务器”的所有中间件信息。

75710

Laravel Eloquent 模型关联关系详解(上)

,第二个参数是关联模型类所属表的外键,这里对应的是 user_profiles 表的 user_id 字段,第三个参数是关联表的外键关联到当前模型所属表的哪个字段,这里对应的是 users 表的 id...第四个参数 relatedPivotKey 是中间表中当前关联模型类的外键,拼接规则和 foreignPivotKey 一样,只不过作用于关联模型类,所以在本例中是 tags 表的 tag_id 字段。...第五个参数 parentKey 表示对应当前模型的哪个字段(即 foreignPivotKey 映射到当前模型所属表的哪个字段),默认是主键 ID,即 posts 表的 id 字段,所以这里不需要额外指定...第六个参数 relatedKey 表示对应关联模型的哪个字段(即 relatedPivotKey 映射到关联模型所属表的哪个字段),默认是关联模型的主键 ID,即 tags 表的 id 字段,所以这里也不需要额外指定...不过中间表默认只返回关联模型的主键字段,如果要返回额外字段,需要在定义关联关系的时候手动指定,比如如果想要返回时间戳信息,可以这么定义: public function tags() { return

9.8K40
领券