Laravel은 코딩 단순화, 개발 효율성 향상, 유지 관리 용이 등 개발자에게 많은 편의를 제공하는 매우 뛰어난 PHP 프레임워크입니다. 동시에 Laravel은 다양한 데이터베이스 작업 방법을 지원하므로 개발자가 데이터베이스 작업을 더 쉽게 수행할 수 있습니다. 이번 글에서는 Laravel 프레임워크에서 데이터베이스 작업을 수행하는 방법을 소개하겠습니다.
1단계: 데이터베이스 정보 설정
먼저 Laravel 프로젝트에서 데이터베이스 정보를 구성해야 합니다. 이는 데이터베이스 유형, 호스트 주소, 포트, 데이터베이스 이름, 사용자 이름 및 비밀번호와 같은 정보를 포함하는 config/database.php 파일에서 구성할 수 있습니다.
Laravel에서는 여러 데이터베이스를 지원할 수 있습니다. 따라서 config/database.php에서 이를 구성해야 합니다. 예:
'connections' => [ 'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, ], 'mysql2' => [ 'driver' => 'mysql', 'host' => env('DB2_HOST', '127.0.0.1'), 'port' => env('DB2_PORT', '3306'), 'database' => env('DB2_DATABASE', 'forge'), 'username' => env('DB2_USERNAME', 'forge'), 'password' => env('DB2_PASSWORD', ''), 'unix_socket' => env('DB2_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, ],
여기서는 서로 다른 데이터베이스에 해당하는 mysql과 mysql2라는 두 개의 데이터베이스 연결이 정의되어 있음을 볼 수 있습니다.
각 데이터베이스의 관련 구성은 .env 파일에서 지정할 수 있습니다:
DB_CONNECTION=mysql DB_HOST=127.0.0.1 DB_PORT=3306 DB_DATABASE=database_name DB_USERNAME=database_username DB_PASSWORD=database_password DB_CONNECTION=mysql2 DB_HOST=127.0.0.1 DB_PORT=3306 DB2_DATABASE=database2_name DB2_USERNAME=database2_username DB2_PASSWORD=database2_password
이러한 구성 정보는 Laravel 애플리케이션에서 사용됩니다.
2단계: 모델 구축
Laravel 프레임워크에서는 모델을 사용하여 데이터베이스와 상호 작용할 수 있습니다. 모델은 데이터베이스에서 데이터를 처리하는 데 사용되는 클래스입니다. 모델을 사용하면 데이터베이스 테이블을 PHP 클래스에 매핑할 수 있어 데이터베이스를 보다 편리하게 운영할 수 있습니다.
Artisan 명령줄 도구를 사용하여 모델을 빠르게 생성하세요. 예:
php artisan make:model User
이렇게 하면 테이블, 기본 키, 타임스탬프 및 기타 정보를 정의할 수 있는 app/Models 디렉터리에 User라는 모델 클래스가 생성됩니다.
namespace App\Models; use Illuminate\Database\Eloquent\Model; class User extends Model { protected $table = 'user'; protected $primaryKey = 'id'; public $timestamps = true; }
3단계: 데이터 쿼리
Laravel에서는 Eloquent ORM을 통해 데이터베이스 쿼리를 쉽게 수행할 수 있습니다. 모델을 사용하면 테이블을 쉽게 쿼리할 수 있습니다. 예를 들어, 다음 Eloquent 메소드를 사용하여 "User" 테이블의 모든 레코드를 가져올 수 있습니다:
use App\Models\User; $users = User::all();
findOrFail 메소드를 사용하여 레코드를 찾을 때 모델 ID와 함께 이 메소드를 사용할 수 있습니다:
$user = User::findOrFail(1);
특정 레코드를 쿼리할 때 , where 메소드를 사용할 수 있습니다:
use App\Models\User; $users = User::where('name', 'John')->get();
다음과 같은 다른 쿼리 조건을 사용할 수도 있습니다:
$user = User::where('name', 'John')->first();
$users = User::select('name')->distinct()->get();
$users = User::orderBy('name', 'desc')->take(10)->get();
4단계: 데이터 삽입
Laravel 프레임워크에 데이터를 삽입하는 것은 매우 간단합니다. 모델을 사용하여 새 레코드를 생성할 때 다음 코드를 사용할 수 있습니다.
$user = new User; $user->name = 'John'; $user->email = 'john@example.com'; $user->save();
클래스에서 create 메소드를 사용하여 한 번에 여러 개의 새 레코드를 생성할 수도 있습니다.
User::create([ 'name' => 'Jane', 'email' => 'jane@example.com', ]);
5단계: 데이터 업데이트
다음을 통해 데이터 업데이트 모델도 매우 쉽습니다. 다음 코드를 통해 레코드를 업데이트할 수 있습니다.
$user = User::find(1); $user->email = 'john.doe@example.com'; $user->save();
일괄적으로 레코드를 업데이트할 수도 있습니다.
User::where('name', 'John')->update(['email' => 'john.doe@example.com']);
6단계: 데이터 삭제
데이터 삭제는 데이터 업데이트와 유사합니다. 단일 레코드를 삭제하려면 다음 명령을 사용하세요.
$user = User::find(1); $user->delete();
여러 레코드를 삭제해야 하는 경우 다음 명령을 사용할 수 있습니다.
User::where('name', 'John')->delete();
삭제 방법을 사용하면 데이터베이스에서 레코드가 영구적으로 삭제됩니다. 영구적으로 삭제하는 대신 일시 삭제 기능을 사용하여 다른 테이블로 이동할 수 있습니다.
요약
Laravel ORM은 프로그래머에게 데이터베이스를 운영할 수 있는 강력한 도구를 제공합니다. 위의 단계를 통해 데이터베이스 쿼리, 삽입, 업데이트, 삭제를 쉽게 수행할 수 있습니다. 민감한 데이터는 세심한 주의와 올바른 행동으로 처리되어야 한다는 점은 주목할 가치가 있습니다. 이 글이 라라벨에서 데이터베이스를 운영하는데 도움이 되기를 바랍니다.
위 내용은 Laravel에서 데이터베이스를 작동하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!