Laravel hasMany and belongsTo parameters(Laravel hasMany 和belongsTo 参数)
问题描述
我有一个表存储,存储有很多库,在库中我有存储store_id的外键.
I have a table store, and store has many libraries, in library I have foreign key of store store_id.
存储表
id(PK)
图书馆表
id(PK)
store_id(FK)
我对 hasMany 和 belongsTo 参数感到困惑,包括在 docs 它说
I'm confused with hasMany and belongsTo parameters include, in the docs it says
return $this->hasMany('AppComment', 'foreign_key');
return $this->hasMany('AppComment', 'foreign_key');
return $this->hasMany('AppComment', 'foreign_key', 'local_key');
return $this->hasMany('AppComment', 'foreign_key', 'local_key');
return $this->belongsTo('AppPost', 'foreign_key', 'other_key');
return $this->belongsTo('AppPost', 'foreign_key', 'other_key');
hasMany foreign_key 和 local_key 来自哪个表?和belongsTo一样,foreign_key和other_key是从哪个表来的?
Which table of hasMany foreign_key and local_key came from? Same with belongsTo which table of foreign_key and other_key came from?
店铺模式
public function library(){
return $this->hasMany('AppLibrary', 'what_foreign_key_should_be_here','what_other_key_should_be_here');
}
图书馆模型
public function stores(){
return $this->belongsTo('AppStores', 'what_foreign_key_should_be_here', 'what_other_key_should_be_here');
}
因为有时候我把一个表的主键id改成sid这样的其他名字,所以我总是想指定哪个是外键和主键
Because sometimes I change my primary key id of a table to other name like sid, so I always want to specify which is foreign key and primary key
推荐答案
为了简化语法,想到了 return $this->hasMany('AppComment', 'foreign_key', 'local_key'); 参数为:
To simplify the syntax, think of the return $this->hasMany('AppComment', 'foreign_key', 'local_key'); parameters as:
- 您要链接到的模型
- 链接回当前表的
id列的外部表(您要链接到的表)的列(除非您指定了第三个参数,在这种情况下它将使用那个) - 应该使用的当前表的列 - 即如果您不希望其他表的外键链接到当前表的
id列
- The model you want to link to
- The column of the foreign table (the table you are linking to) that links back to the
idcolumn of the current table (unless you are specifying the third parameter, in which case it will use that) - The column of the current table that should be used - i.e if you don't want the foreign key of the other table to link to the
idcolumn of the current table
在您的情况下,因为您在 libraries 表中使用了 store_id,您的生活变得轻松了.在您的 Store 模型中定义时,以下内容应该可以完美运行:
In your circumstance, because you have used store_id in the libraries table, you've made life easy for yourself. The below should work perfectly when defined in your Store model:
public function libraries()
{
return $this->hasMany('AppLibrary');
}
在幕后,Laravel 会自动将Store 表的id 列链接到Library<的store_id 列/code> 表格.
Behind the scenes, Laravel will automatically link the id column of the Store table to the store_id column of the Library table.
如果你想明确定义它,那么你可以这样做:
If you wanted to explicitly define it, then you would do it like this:
public function libraries(){
return $this->hasMany('AppLibrary', 'store_id','id');
}
- 模型标准是单数命名的函数返回一个belongsTo,而复数函数返回一个hasMany(即
$store->libraries() 或$library->store()).
这篇关于Laravel hasMany 和belongsTo 参数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Laravel hasMany 和belongsTo 参数
基础教程推荐
- 学说 dbal querybuilder 作为准备好的语句 2022-01-01
- YouTube API v3 点赞视频,但计数器不增加 2022-01-01
- 有什么方法可以用编码 UTF-8 而不是 Unicode 返回 PHP`json_encode`? 2021-01-01
- 如何替换eregi() 2022-01-01
- PHP PDO MySQL 查询 LIKE ->多个关键词 2021-01-01
- Cron Jobs 调用带有变量的 PHP 脚本 2022-01-01
- 如何在 Laravel 5.3 注册中添加动态下拉列表列? 2021-01-01
- PHP 类:全局变量作为类中的属性 2021-01-01
- 在PHP中根据W3C规范Unicode 2022-01-01
- 如何在 Laravel 中使用 React Router? 2022-01-01
