簡體   English   中英

使用 BackPack 時,表中必須有一個“id”列嗎?

[英]Is having an "id" column in a table mandatory to work with BackPack?

我有一個包含color_idlist_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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM