매직을 사용합니다.최근 편집자는 세계 최고의 프레임워크로 알려진 Laravel을 연구하고 있습니다. 사실, 학습 프레임워크는 학습 프레임워크의 아이디어입니다! 저는 라라벨을 배우면서 겪은 경험을 블로그에 기록하고 싶습니다. 누구나 제 다른 Git허브 블로그와 짧은 책을 팔로우하여 서로 소통할 수 있습니다!
버전: Laravel 5.2
Appearance 객체의 static 메소드를 사용하여 SQL 쿼리를 직접 실행하는 것이고, 다른 하나는 Model 클래스의 static 메소드를 사용하는 것입니다(실제로는 Static 접근을 사용하는 Facade의 구현이기도 합니다). 내부적으로
데이터베이스: mysql 5.7
PHP7.1 하나는
$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
$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();
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!