我对laravel真的很陌生,我确定我做错了什么
我有 2 张桌子。Cities
和users_metadata
我的城市表看起来像这样
id | City |
1 | New York |
1 | Los Angeles |
用户元数据
user_id | firt name | last name | cities_id |
1 | Jonh | Doe | 2 |
所以我的问题是当我创建一个关系时我得到了纽约,因为城市 ID 与用户 ID 匹配
城市模型
class City extends Eloquent
{
public static $table = "cities";
public function profile()
{
return static::has_many('Profile');
}
}
轮廓模型
class Profile extends Eloquent
{
public static $timestamps = false;
public static $table = "users_metadata";
public static $key = "user_id";
public function city()
{
return static::has_one('City');
}
}
错误
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'profile_id' in 'where clause'
SQL: SELECT * FROM `cities` WHERE `profile_id` = ? LIMIT 1
Bindings: array (
0 => 1,
)
如果我没有将 id 传递给拥有一个,我会收到以下错误
好的,我明白这一点。
所以我的问题是我能够以cities_id
某种方式在我的匹配关系中传递外键吗?还是我做错了?有人可以给我一个基本的例子吗?
谢谢各位