Laravel은 가장 인기 있는 오픈 소스 PHP 웹 애플리케이션 프레임워크 중 하나입니다. 사용 편의성, 효율성 및 유연성으로 인해 점점 더 많은 개발자가 Laravel을 사용하여 고품질 웹 애플리케이션을 만들고 있습니다.
Laravel에서는 일대다 데이터 관계, 즉 마스터 테이블과 여러 슬레이브 테이블 간의 관계를 자주 접하게 됩니다. 이 관계는 데이터베이스의 외래 키를 통해 달성될 수 있습니다. Laravel에서는 Eloquent ORM(Object-Relational Mapping)을 사용하여 일대다 데이터 쿼리 작업을 쉽게 수행할 수 있습니다. 이번 글에서는 라라벨에서 일대다 데이터 관계를 쿼리하고 취소하는 방법을 주로 소개합니다.
1. 일대다 데이터 관계 쿼리
Laravel에서는 Eloquent ORM을 사용하여 일대다 데이터 관계를 쿼리할 수 있습니다. 먼저 해당 모델과 관계를 정의해야 합니다. 예를 들어 "users" 테이블과 "orders" 테이블이 있습니다. 각 사용자는 이를 나타내기 위해 여러 주문을 가질 수 있습니다. . 일대다 관계:
class User extends Model { /** * 获取与用户相关联的所有订单。 */ public function orders() { return $this->hasMany('AppOrder'); } }
위 코드에서는 hasMany() 메서드를 사용하여 사용자와 관련된 모든 주문을 정의합니다. 이 메서드는 두 개의 매개변수를 받습니다. 첫 번째 매개변수는 종속 모델의 이름입니다. 두 번째 첫 번째 매개변수는 외래 키의 이름입니다(기본적으로 외래 키 이름은 종속 모델 이름에 _id를 더한 이름입니다). 다음으로, 다음과 같이 Orders() 메서드를 사용하여 사용자와 관련된 모든 주문을 쿼리할 수 있습니다.
$user = User::find(1); // 获取与用户相关联的所有订单 $orders = $user->orders;
위 코드에서는 먼저 find() 메서드를 사용하여 ID 1의 사용자 개체를 찾은 다음 $를 사용합니다. user->orders - 이 사용자와 관련된 모든 주문을 가져옵니다.
주문을 추가로 필터링해야 하는 경우 쿼리 빌더를 사용하여 쿼리를 필터링할 수 있습니다. 예:
// 获取与用户相关联的价格超过10元的订单 $orders = $user->orders()->where('price', '>', 10)->get();
위 코드에서는 where() 메서드를 사용하여 가격이 10위안을 초과하는 주문을 필터링합니다.
2. 일대다 데이터 관계 취소
때때로 Laravel에서는 마스터 테이블과 슬레이브 테이블 간의 일대다 관계를 취소해야 할 때가 있습니다. 예를 들어, 주문을 사용자에게 종속시키고 연관되지 않게 만들 수 있습니다.
Laravel에서는 외래 키를 null로 설정하여 레코드와 종속 모델 간의 관계를 취소할 수 있습니다. 예를 들어 ID 1의 주문을 ID 2의 사용자에게 종속시키려면 다음과 같이 할 수 있습니다.
$order = Order::find(1); // 取消该订单与之关联的用户 $order->user_id = null; $order->save();
위 코드에서는 먼저 find() 메서드를 사용하여 ID가 있는 주문 객체를 찾습니다. 1 그런 다음 주문의 user_id 속성을 null로 설정하고 마지막으로 save() 메서드를 사용하여 변경 사항을 저장합니다.
사용자와 모든 관련 주문 간의 관계를 취소해야 하는 경우 다음과 같이 할 수 있습니다.
$user = User::find(1); // 取消该用户与相关联订单之间的关系 $user->orders()->update(['user_id' => null]);
위 코드에서는 먼저 find() 메서드를 사용하여 ID가 1인 사용자 개체를 찾습니다. 그런 다음 주문() 메서드를 사용하여 사용자와 관련된 모든 주문을 얻은 다음 update() 메서드를 사용하여 모든 주문의 user_id 속성을 null로 설정합니다.
3. 요약
Laravel에서는 Eloquent ORM을 사용하여 일대다 데이터 쿼리 작업을 쉽게 수행할 수 있습니다. 일반적으로 해당 모델과 관계를 정의하여 일대다 데이터 관계를 구현할 수 있으며 쿼리 빌더를 사용하여 쿼리할 때 데이터를 추가로 필터링할 수 있습니다. 동시에 일반적으로 외래 키를 null로 설정하여 마스터 테이블과 슬레이브 테이블 간의 일대다 관계를 취소할 수도 있습니다. Laravel 애플리케이션을 작성할 때 개발 효율성과 작성된 코드의 품질을 향상시키기 위해 Eloquent ORM의 기능을 최대한 활용해야 합니다.
위 내용은 laravel 쿼리는 일대다 취소의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!