SQLSTATE [42S22]: Столбец не найден: 1054 Неизвестный столбец 'produk.id' в 'where clause' (SQL: выберите * из `produk`, где` produk`.`id` = 65 limit 1)

Illuminate \ Database \ QueryException (42S22) SQLSTATE[42S22]: Column not found: 1054 Unknown column 'produk.id' in 'where clause' (SQL: select * from produk where produk.id = 65 limit 1)

Не знаю где ошибка после моего кода, который показывает ошибку:

public function update(Request $request, $id)
{
    $this->validate($request, $this->aturan, $this->pesan);

    $produk = produk::find($id);
    $produk->nama_produk = $request['nama'];
    $produk->id_kategori = $request['kategori'];
    $produk->harga_jual = $request['harga'];
    $produk->update();

    return Redirect::route('produk.index');
}

/**
 * Remove the specified resource from storage.
 *
 * @param  int  $id
 * @return \Illuminate\Http\Response
 */
public function destroy($id)
{
    $produk = Produk::find($id);
    $produk->delete();
    return Redirect::route('produk.index');  
}

Можете ли вы поделиться своей схемой таблицы mysql (SHOW CREATE TABLE)?

HorusKol 03.08.2018 01:27
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
1
1 350
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

Согласно документации Eloquent, если ваша модель использует другой первичный ключ, чем id, вы должны это настроить. Eloquent ожидает, что первичным ключом будет id, и что по умолчанию это целое число с автоинкрементом.

YourModel extends Eloquent ...
{
    protected $primaryKey = 'yourOtherKey';
    ...
}

"Eloquent will also assume that each table has a primary key column named id. You may define a protected $primaryKey property to override this convention."

"In addition, Eloquent assumes that the primary key is an incrementing integer value, which means that by default the primary key will be cast to an int automatically. If you wish to use a non-incrementing or a non-numeric primary key you must set the public $incrementing property on your model to false. If your primary key is not an integer, you should set the protected $keyType property on your model to string."

Laravel 5.6 Docs - Eloquent - Типовые соглашения

попробуйте вместо этого findOrFail

$produk = produk::findOrFail($id);

Другие вопросы по теме