質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.77%

[laravel]削除機能にidとは別に表示上の連番機能を追加したい

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 507

twinparadox

score 42

環境

laravel 6
mysql 8

実現したい事

idとは別にtodo_idカラムを用意して削除処理時に表示上の連番機能を実装したい。

①タスク削除時はID(中身はtodo_id)が1から振り直される
②削除後、新たにタスクを追加するとID(中身はtodo_id)が連番となっている

実装したい内容

todo_id 追加して連番を振る
todos テーブルから todo_id の最大値 + 1 取得して設定する
削除後はデータを再取得して頭から1スタートで振り直す
新規追加時は todo_id の最大値 + 1 を振る 

ここまで考えたのですが具体的なコーディングが分からずに悩んでいます。
教えて頂けないでしょうか?

やった事

下記コードの実装(エラー内容も記載してます)

create_todo_table.php

<?php

use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;

class CreateTodoTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('Todos', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->char('comment');
            $table->integer('todo_id');
            $table->timestamps();
        });
    }

    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('Todos');
    }
}

todo.php

<?php

namespace App;

use Illuminate\Database\Eloquent\Model;

class Todo extends Model
{
    protected $table = 'Todos';
    protected $guarded = array('id');
    public static $rules = array(
        'comment' => 'required'
    );
}

TodoController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests\CreateTaskRequest;
use Illuminate\Support\Facades\DB;
use App\Todo;

class TodoController extends Controller
{
  public function index(Request $request)
  {
    $items = Todo::all();
    return view('Todos.index', ['items' => $items]);
  }

  public function create(CreateTaskRequest $request)
  {
    $todo = new Todo;
    $form = $request->all();
    unset($form['_token']);
    $todo->timestamps = false;
    $todo->fill($form)->save();
    $param = [
      'id' => $request->id,
      'comment' => $request->comment,
      'todo_id' => $request->todo_id,
    ];


    return redirect('/Todo');
  }
  public function delete(Request $request)
  {
    Todo::find($request->table)->delete();
    $items = DB::table('Todos')->orderBy('todo_id', 'asc')->get();

    return redirect('/Todo');
  }
}

web.php

<?php

/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/

Route::get('/', function () {
    return view('welcome');
});


Route::get('/Todo', 'TodoController@index');
Route::post('/Todo', 'TodoController@create');
Route::group(['middleware' => ['web']], function () {
    Route::post('/Todo', 'TodoController@create');
});
Route::delete('/Todo/{table}', 'TodoController@delete');

views/Todos/index.blade.php

@extends('layouts.index')
@section('title','Todoリスト')
@section('menubar')
@parent
Todoリスト
@endsection

@section('content')


<table>
  <tr>
    <th>ID</th>
    <th>コメント</th>
    <th>状態</th>
  </tr>
  @foreach ($items as $item)
  <tr>
    <td>{{$item->todo_id}}</td>
    <td>{{$item->comment}}</td>
    <td>作業中</td>
    <td>
      <form action="{{ url('Todo/' . $item->todo_id) }}" method="POST">
        @csrf
        @method('DELETE')

        <button type="submit">
          削除
        </button>
      </form>
    </td>
  </tr>
  @endforeach
</table>
@endsection

エラー文

Illuminate\Database\QueryException
SQLSTATE[HY000]: General error: 1364 Field 'todo_id' doesn't have a default value (SQL: insert into `Todos` (`comment`) values (modelを使ったデータ))
http://localhost/Todo
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2020/01/11 14:41

    クラス名とファイル名が一致してないですけど、これってオートローダーから読めないのでは。

    キャンセル

  • キャンセル

  • twinparadox

    2020/01/11 15:38

    どこの部分でしょうか?

    キャンセル

  • m.ts10806

    2020/01/11 15:44

    ご自身のコードですよね?見ればわかります。

    create_todo_table.php CreateTodoTable

    todo.php
    Todo

    キャンセル

回答 2

+2

ページングがなければforeachのindexに1足したもので良いのではないでしょうか

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/01/12 05:17

    返信ありがとうございます。考えてみます。

    キャンセル

checkベストアンサー

+1

たまに見るけど振り直すって発想がどこから出てくるのか分からない。
いちいち振り直すとか面倒なのでやらない。

<td>{{$item->todo_id}}</td>の代わりに$loop->iterationで表示する時に連番を得られる。
表示時に必要な連番ならこれで十分。

  @foreach ($items as $item)
  <tr>
    <td>{{ $loop->iteration }}</td>
    <td>{{$item->comment}}</td>

https://readouble.com/laravel/6.x/ja/blade.html#the-loop-variable

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/01/12 05:16

    ありがとうございます。
    エラーに関してはどう思われますか?

    SET GLOBAL sql_mode=NO_ENGINE_SUBSTITUTION;

    の方法で設定しましたが同様の
    SQLSTATE[HY000]: General error: 1364 Field 'todo_id' doesn't have a default value
    が発生してしまいます。。。
    何なんでしょうか。

    キャンセル

  • 2020/01/12 15:37

    解決しました

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.77%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る