Laravel 학습-데이터베이스 작업 및 쿼리 생성자를 위한 샘플 코드 공유
매직을 사용합니다.최근 편집자는 세계 최고의 프레임워크로 알려진 Laravel을 연구하고 있습니다. 사실, 학습 프레임워크는 학습 프레임워크의 아이디어입니다! 저는 라라벨을 배우면서 겪은 경험을 블로그에 기록하고 싶습니다. 누구나 제 다른 Git허브 블로그와 짧은 책을 팔로우하여 서로 소통할 수 있습니다!
버전: Laravel 5.2
Appearance 객체의 static 메소드를 사용하여 SQL 쿼리를 직접 실행하는 것이고, 다른 하나는 Model 클래스의 static 메소드를 사용하는 것입니다(실제로는 Static 접근을 사용하는 Facade의 구현이기도 합니다). 내부적으로
데이터베이스: mysql 5.7
PHP7.1 하나는
쿼리 작업sql 문을 사용하여 쿼리 선택 작업을 실행합니다. #$results = DB::select('select * from users where id = ?', [1]);foreach ($results as $res) { echo $res->name;
}
로그인 후 복사
반환 결과는 배열이고, 배열의 각 값은 $results = DB::select('select * from users where id = ?', [1]);foreach ($results as $res) { echo $res->name; }
Object.DB
더 명확한 이 방법을 사용하는 것이 좋습니다. callStatic
데이터 테이블에서 모든 데이터 열을 가져옵니다.
첫 번째 방법을 사용하여 데이터의 단일 행을 반환합니다.
$results = DB::select('select * from users where id = :id', ['id' => 1]);
한 열의 값만 필요한 경우 value 메서드를 사용하여 단일 열의 값을 직접 얻을 수 있습니다.
$users = DB::table('users')->get(); foreach ($users as $user) { var_dump($user->name); }
데이터 테이블에서 데이터 열을 청크로 찾아보세요StdClass
이 방법은 데이터 테이블에 많은 양의 데이터가 있는 작업에 사용됩니다. 결과 집합의 일부를 꺼내어 클로저 함수를 사용하여 처리한 후 다음 부분을 처리할 때마다 이 명령은 Artisan 명령줄 프로그램에서 일반적으로 사용됩니다.
$user = DB::table('users')->where('name', 'John')->first(); echo $user->name;
클로저 함수에서
이 반환되면 후속 처리가 중지됩니다.데이터 테이블에서 특정 열의 목록을 쿼리합니다.
예를 들어 역할 테이블의 모든
필드 값을 쿼리하려고 합니다.$email = DB::table('users')->where('name', 'John')->value('email');
함수가 있습니다. 매개변수
DB::table('users')->chunk(100, function($users){ foreach ($users as $user) { // } });
첫 번째 매개변수는 두 번째 매개변수는 각 열의 키
$titles = DB::table('roles')->pluck('title');foreach ($titles as $title) { echo $title; }
집계 함수false
등 일부 집계 함수도 제공합니다.
Collection pluck( string $column, string|null $key = null)
select 쿼리 조건 지정 title
$roles = DB::table('roles')->pluck('title', 'name');foreach ($roles as $name => $title) { echo $title; }
pluck
select를 지정했지만 일부 필드를 다시 추가하려면 addSelect 메서드를 사용하세요$users = DB::table('users')->count(); $price = DB::table('orders')->max('price'); $price = DB::table('orders')->where('finalized', 1)->avg('price');
다른 결과 쿼리 구별#
$users = DB::table('users')->select('name', 'email as user_email')->get();
기본
표현식 사용#count,max,min,avg,sum
메서드를 사용하여 쿼리 필수 SQL 조각에 삽입하지만 이 방법은 매우 잘못 사용하면 SQL 주입이 발생할 수 있습니다.
$query = DB::table('users')->select('name');$users = $query->addSelect('age')->get();
Join 연산
Inner Join#
Join을 사용하여 내부 Connection 연산을 실행합니다. 다른 매개변수는 연결 제약 조건을 지정합니다.
$users = DB::table('users')->distinct()->get();
Left Join# leftJoin 메서드를 사용하여 왼쪽 조인 작업을 수행합니다. 매개변수는 Join$ 사용자와 동일합니다. =
$users = DB::table('users') ->select(DB::raw('count(*) as user_count, status')) ->where('status', '<>', 1) ->groupBy('status') ->get();
DB::raw
조인 방법의 제약 조건이 더 복잡하다면 클로저 기능을 사용하여
$users = DB::table('users') ->join('contacts', 'users.id', '=', 'contacts.user_id') ->join('orders', 'users.id', '=', 'orders.user_id') ->select('users.*', 'contacts.phone', 'orders.price') ->get();
열을 사용할지 여부를 지정할 수 있습니다. 조인 제약 조건에서 지정된 배열과 값을 비교하려면 where 및 OrWhere 메서드를 사용할 수 있습니다.
DB::table('users') ->leftJoin('posts', 'users.id', '=', 'posts.user_id') ->get();
Union 연산
Union 연산을 사용하려면 먼저 쿼리를 생성하고 그런 다음 Union 메서드를 사용하여 두 번째 쿼리
<p style="margin-top: 7px;">DB::table('users')<br/> ->join('contacts', function ($join) {<br/> $join->on('users.id', '=', 'contacts.user_id')->orOn(...);<br/> })<br/> ->get();<br/></p>
를 바인딩합니다. 마찬가지로
메서드도 Union과 동일한 매개변수로 사용할 수 있습니다.
Where 쿼리 조건
간단한 where 조건#
where 메소드를 사용하여 쿼리에 where 조건을 추가합니다. 이 함수에는 일반적으로 열 이름, 연산자(모든 데이터베이스에서 지원하는 모든 연산자를 사용할 수 있습니다), 열 값.
아아아아위 내용은 Laravel 학습-데이터베이스 작업 및 쿼리 생성자를 위한 샘플 코드 공유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Laravel 이메일 전송이 실패 할 때 반환 코드를 얻는 방법. Laravel을 사용하여 응용 프로그램을 개발할 때 종종 확인 코드를 보내야하는 상황이 발생합니다. 그리고 실제로 ...

laravel 일정 작업 실행 비 응답 문제 해결 Laravel의 일정 작업 일정을 사용할 때 많은 개발자 가이 문제에 직면합니다 : 스케줄 : 실행 ...

Laravel의 이메일을 처리하지 않는 방법은 LaRavel을 사용하는 것입니다.

DCAT를 사용할 때 DCATADMIN (LARAVEL-ADMIN)에서 데이터를 추가하려면 사용자 정의의 테이블 기능을 구현하는 방법 ...

Laravel - 덤프 서버 - Laravel 덤프 서버는 Laravel 5.7 버전과 함께 제공됩니다. 이전 버전에는 덤프 서버가 포함되어 있지 않습니다. 덤프 서버는 laravel/laravel 작곡가 파일의 개발 종속성이 됩니다.

Laravel 프레임 워크 및 Laravel 프레임 워크 및 Redis를 사용할 때 Redis 연결을 공유하는 데 영향을 줄 수 있습니다. 개발자는 문제가 발생할 수 있습니다. 구성을 통해 ...

Laravel 다중 테넌트 확장 패키지 패키지 패키지 패키지 패키지 Stancl/Tenancy, ...

Laravel - 액션 URL - Laravel 5.7에는 "호출 가능한 액션 URL"이라는 새로운 기능이 도입되었습니다. 이 기능은 액션 메소드에서 문자열을 허용하는 Laravel 5.6의 기능과 유사합니다. Laravel 5.7에 도입된 새로운 구문의 주요 목적은
