MySQL의 조건부 삽입 문
SQL에서 INSERT 문은 일반적으로 데이터베이스 테이블에 레코드를 삽입하는 데 사용됩니다. 그런데 특정 조건을 만족하는 경우에만 레코드를 삽입해야 한다면 어떻게 될까요? 조건부 INSERT를 수행할 수 있습니까?
문제 설명
"제품"과 "주문"이라는 두 개의 테이블이 있는 시나리오를 생각해 보세요. "제품" 테이블에는 제품 세부 정보와 보유 수량(qty_on_hand)이 저장됩니다. "주문" 테이블은 주문 세부정보를 추적합니다.
특정 제품에 대한 주문이 들어왔고 이를 처리하기에 충분한 수량이 있는지 확인해야 한다고 가정해 보겠습니다. 전통적으로 별도의 쿼리를 실행하여 보유 수량을 확인한 다음 조건이 충족되면 INSERT를 수행했습니다. 그러나 이 접근 방식은 동시성 문제에 취약합니다.
조건부 삽입 솔루션
MySQL은 SELECT...WHERE 구문을 사용하여 조건부 삽입을 수행하는 편리한 방법을 제공합니다.
이 구문을 사용하면 SELECT 문이 지정된 조건을 충족하는 행을 반환하는 경우에만 테이블에 행을 삽입할 수 있습니다. 예:
이 쿼리에서 하위 쿼리가 20보다 큰 값(충분한 재고를 나타냄)을 반환하는 경우 INSERT 문은 제품 ID가 2인 "주문" 테이블에 행을 추가합니다. 수량은 20개입니다. 그렇지 않으면 행이 없습니다. 삽입되었습니다.
이점
조건부 INSERT 문을 사용하면 여러 가지 이점이 있습니다.
위 내용은 MySQL에서 조건부 삽입을 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!