[英]Is having an "id" column in a table mandatory to work with BackPack?
我有一個包含color_id
和list_id
列的表。 當我在 Laravel BackPack 中加載帶有特定 model 的頁面時,它會拋出錯誤:
SQLSTATE[42703]: Undefined column: 7 ERROR: column "id" does not exist LINE 1: select * from "color_list" order by "id" desc l... ^ (SQL: select * from "color_list" order by "id" desc limit 10)
一般來說,這是正確的。 我沒有id
列,因為它是一個 pivot 表。 我假設添加自定義排序可以解決問題,所以我在控制器的setup()
方法中添加了以下行:
$this->crud->addClause('orderBy', 'color_id', 'DESC');
這並沒有解決問題,BackPack 仍在嘗試搜索id
列。
SQLSTATE[42703]: Undefined column: 7 ERROR: column "id" does not exist LINE 1: ...color_list" order by "color_id" desc, "id" desc ... ^ (SQL: select * from "color_list" order by "color_id" desc, "id" desc limit 10)
有沒有辦法解決它? 我真的需要在我的表中添加一個id
列嗎?
通過將此添加到我的 model,我暫時能夠解決它:
protected $primaryKey = 'color_id';
但這真的是唯一的解決辦法嗎?
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.