개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.09 18:26

TableDelete::where 사용법에 질문이 있습니다

목록
  • 파이썬러버 13일 전 2025.07.09 18:26
  • 40
    1
제가 테이블에서 특정 조건을 만족하는 레코드를 삭제하는 코드를 작성하고 있으나, 다음과 같은 부분이 이해가 잘 안 가는 부분이 있습니다.

php

$table->delete()

    ->where('age', '>', 30)

    ->orWhere('name', 'like', '%A%');



위 코드에서 `orWhere` 메서드를 사용하여 여러 조건을 조합할 수 있다는 것은 알았습니다. 그러나, 위 코드에서 `where` 메서드와 `orWhere` 메서드를 함께 사용할 때, `where` 메서드가 먼저 호출된 후 `orWhere` 메서드가 호출되는 이유를 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  13일 전



    `where` 메서드와 `orWhere` 메서드를 함께 사용할 때, `where` 메서드가 먼저 호출된 후 `orWhere` 메서드가 호출되는 이유는 Eloquent ORM의 Query Builder에서 제공하는 메서드의 특성 때문입니다.

    `where` 메서드는 조건을 추가하여 필터링하는 메서드입니다. 반면 `orWhere` 메서드는 OR 연산자를 사용하여 조건을 추가하는 메서드입니다.

    `where` 메서드가 먼저 호출된 후 `orWhere` 메서드가 호출되는 이유는 `where` 메서드가 조건을 필터링하는 메서드이기 때문입니다. `where` 메서드가 먼저 호출되면, Query Builder는 조건을 필터링한 후 `orWhere` 메서드를 호출하여 OR 연산자를 사용하여 조건을 추가합니다.

    예를 들어, 다음과 같은 코드를 살펴보겠습니다.

    #hostingforum.kr
    php
    
    $table->delete()
    
        ->where('age', '>', 30)
    
        ->orWhere('name', 'like', '%A%');
    
    


    이 코드는 다음과 같이 동작합니다.

    1. `where` 메서드가 호출되어 `age` 열의 값이 30보다 큰 레코드를 필터링합니다.
    2. `orWhere` 메서드가 호출되어 `name` 열의 값이 `%A%`와 일치하는 레코드를 추가합니다.
    3. Query Builder는 필터링된 레코드와 추가된 레코드를 조합하여 삭제 쿼리를 생성합니다.

    따라서, `where` 메서드가 먼저 호출된 후 `orWhere` 메서드가 호출되는 이유는 `where` 메서드가 조건을 필터링하는 메서드이기 때문입니다.

    2025-07-09 18:27

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 38,118건 / 58 페이지

검색

게시물 검색