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

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

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Q&A

解決済

1回答

2257閲覧

[laravel]削除機能を追加したい

twinparadox

総合スコア42

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

0グッド

0クリップ

投稿2020/01/08 21:07

編集2020/01/08 21:16

#やりたいこと
laravelを使用してTodorリストに削除機能を実装中です。
削除処理は出来たのですが、その後の要件を満たす為どのような実装をすればいいか悩んでいます。
①タスク削除時はIDが1から振り直される
②削除後、新たにタスクを追加するとIDが連番となっている

完成イメージ

現在の実装ではidを全て消しても41〜となりオートインクリメントが働いている状態。

#やったこと
①orderByの実装

$items = DB::select('ALTER TABLE `tablename` auto_increment = 1');

の実装

②を行う前に全テーブルを削除しmigrateを行いました。

下記コードは②のコードになります。

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, ]; return redirect('/Todo'); } public function delete(Request $request) { Todo::find($request->table)->delete(); $items = DB::select('ALTER TABLE `tablename` auto_increment = 1'); 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');

view/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->id}}</td> <td>{{$item->comment}}</td> <td>作業中</td> <td> <form action="{{ url('Todo/' . $item->id) }}" method="POST"> @csrf @method('DELETE') <button type="submit">削除</button> </form> </td> </tr> @endforeach </table> @endsection

気になる質問をクリップする

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/01/08 21:27

>①タスク削除時はIDが1から振り直される ②削除後、新たにタスクを追加するとIDが連番となっている 「そうしたい」のかもしれませんが、そうすることによるメリットはないですし、 通常はやりませんよ。 それに振りなおしては折角のauto_incrementの意味がありません。
twinparadox

2020/01/09 03:46

なるほど。 考えてみます。ありがとうございます。
guest

回答1

0

ベストアンサー

  • ID は一度使用したら二度とその番号を使わないというのが大原則です。リクエストのタイミングによって同じ ID が違うものを指していたら、その処理は安全ではありません。
  • 通常リレーショナルデータベースにおいては、ユーザ1人だけではなく全員のユーザで1つのテーブルを共有するため、上記を差し置いてもこのアプローチを使えるケースは非常に稀です。ユーザ1人ごとにテーブルを1つ生成するのはアンチパターンであり、このような設計になることは滅多にありません。

おそらく見た目上の問題でそのような発想をされたのだと思いますが、アプローチの方法が不適当です。自分の経験則的にはバックエンドではなくフロントエンドで処理するほうが正解だと思います。もし連番で No.1 No.2 のような通し番号を振りたいなら、以下のような方法があります。

もしどうしても最初の仕様を望むのであれば、IDとは別のカラムを使って手動で連番を振る必要があります。コストに対してリターンが少ないのであまり使われることはないと思いますが。連続でリクエストがきたときに番号が被って不正なデータが生まれたりエラーになったりするので、ユーザごとにユニークインデックスを貼ったりトランザクションを張ったりするのは必須になってしまいますね。

投稿2020/01/08 22:11

mpyw

総合スコア5223

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

twinparadox

2020/01/09 04:22 編集

丁寧で分かりやすい回答ありがとうございます。 言われてみるとその通りだと感じました。 では新たにorderカラムの追加などをして対象データをソートして全取得、ループで1から設定し直せばいいのでしょうか?
mpyw

2020/01/15 08:21

基本的にはそうなります!ですが既に回答したようにトランザクションなどを使用して,同時にアクセスがきた場合でもある程度の整合性に関する安全を担保できるようにしてください
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問