>  기사  >  PHP 프레임워크  >  laravel 쿼리는 일대다 취소

laravel 쿼리는 일대다 취소

WBOY
WBOY원래의
2023-05-29 14:49:08697검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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