>PHP 프레임워크 >Laravel >laravel에서 일괄 삭제 기능을 구현하는 방법

laravel에서 일괄 삭제 기능을 구현하는 방법

PHPz
PHPz원래의
2023-04-11 15:07:411636검색

웹 애플리케이션이 점점 대중화되면서 데이터 관리는 필수 기술이 되었습니다. 그러나 많은 양의 데이터를 관리하는 것은 지루한 작업이 될 수 있으며, 특히 삭제를 처리할 때 더욱 그렇습니다. 다행스럽게도 Laravel 프레임워크는 데이터 대량 삭제 작업을 처리하는 간단하면서도 효과적인 방법을 제공합니다. 이 글에서는 Laravel에서 일괄 삭제를 구현하여 대량의 데이터를 처리할 때 더욱 유연하고 효율적으로 만드는 방법을 알아봅니다.

1단계: 모델 설정

시작하기 전에 데이터베이스 테이블 관리를 위한 모델 클래스가 있는지 확인해야 합니다. 예를 들어, admins 테이블을 관리하기 위한 관리 모델 클래스를 생성해 보겠습니다. 다음 명령을 사용하여 이 모델을 생성할 수 있습니다.

php artisan make:model Admin

이렇게 하면 관리자 테이블을 관리하기 위한 모델 클래스가 포함된 앱 디렉터리에 Admin.php 파일이 생성됩니다.

2단계: 삭제 방법 추가

이제 관리자를 삭제하는 방법을 추가해 보겠습니다. 관리 모델 클래스에 다음 코드를 추가하세요:

public static function deleteByIds(array $ids)
{
    return self::whereIn('id', $ids)->delete();
}

이 메서드에서는 Laravel의 whereIn() 메서드를 사용하여 전달된 ID 배열과 일치하는 레코드를 찾습니다. 마지막으로 delete() 메소드를 사용하여 일치하는 레코드를 삭제합니다.

3단계: 컨트롤러 생성

이제 데이터 삭제 요청을 처리할 컨트롤러 클래스를 생성해야 합니다. 다음 명령을 사용하여 이 컨트롤러를 생성할 수 있습니다.

php artisan make:controller AdminController --resource

이렇게 하면 리소스 컨트롤러 클래스가 포함된 app/Http/Controllers 디렉터리에 AdminController.php 파일이 생성됩니다.

4단계: 경로 정의

다음으로 관리자 대량 삭제를 위한 경로를 정의해야 합니다. web.php 파일에 다음 코드를 추가하세요:

Route::delete('/admins/delete', 'AdminController@delete')->name('admins.delete');

이렇게 하면 AdminController 클래스의 delete() 메서드에 의해 생성된 요청을 처리하기 위한 경로가 생성됩니다. 또한 나중에 보기에서 참조할 수 있도록 경로 이름을 admins.delete로 지정합니다.

5단계: 보기 만들기

마지막으로 사용 가능한 모든 관리자 기록을 표시하고 사용자가 삭제해야 하는 기록을 선택할 수 있는 보기를 만들어야 합니다. 다음 코드를 사용하여 이 뷰를 만들 수 있습니다.

@extends('layouts.app')

@section('content')
    <form action="{{route(&#39;admins.delete&#39;)}}" method="POST">
        @csrf
        @method('delete')

        <button type="submit" class="btn btn-primary mb-2">Delete Selected</button>

        <table class="table">
            <thead>
            <tr>
                <th scope="col">#</th>
                <th scope="col">Name</th>
                <th scope="col">Email</th>
                <th scope="col">Actions</th>
            </tr>
            </thead>
            <tbody>
            @foreach ($admins as $admin)
                <tr>
                    <th scope="row">{{ $admin->id }}</th>
                    <td>{{ $admin->name }}</td>
                    <td>{{ $admin->email }}</td>
                    <td>
                        <input type="checkbox" name="ids[]" value="{{ $admin->id }}">
                    </td>
                </tr>
            @endforeach
            </tbody>
        </table>
    </form>
@endsection

이 뷰에서는 모든 관리자 레코드가 포함된 테이블을 만듭니다. 또한 사용자가 삭제할 레코드를 선택할 수 있는 확인란과 이전 단계에서 정의한 삭제 경로를 호출하는 제출 버튼을 추가했습니다. 이 보기는 resources/views/admins/index.blade.php 파일에 저장되어야 합니다.

6단계: 삭제 요청 처리

이제 경로와 보기가 설정되었으므로 대량 삭제 요청을 처리하기 위해 컨트롤러 클래스에 메소드를 추가해야 합니다.

public function delete(Request $request)
{
    $ids = $request->ids;
    Admin::deleteByIds($ids);

    return redirect()->back()->with('success', 'Selected admins have been deleted!');
}

이 메소드에서는 선택된 모든 ID를 기록합니다. 모델 클래스에 정의한 deleteByIds() 메서드에 전달합니다. 마지막으로 뷰로 다시 리디렉션하고 성공 메시지를 표시합니다.

Summary

이 글에서는 Laravel 프레임워크를 사용하여 데이터베이스 레코드를 일괄 삭제하는 방법을 배웠습니다. 데이터를 관리하기 위한 모델 클래스와 컨트롤러 클래스를 만들고, 삭제 요청을 처리하기 위한 경로를 정의하고, 데이터를 표시하고 사용자 입력을 처리하기 위한 뷰를 만들었습니다. 이제 웹 애플리케이션의 데이터를 관리할 수 있는 강력한 도구가 있어 더욱 유연하고 효율적으로 작업할 수 있습니다.

위 내용은 laravel에서 일괄 삭제 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.