>데이터 베이스 >MySQL 튜토리얼 >제조업체 지역 설정을 기반으로 MySQL에서 제품 가시성을 어떻게 동적으로 결정할 수 있습니까?

제조업체 지역 설정을 기반으로 MySQL에서 제품 가시성을 어떻게 동적으로 결정할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-25 00:37:12486검색

How Can I Dynamically Determine Product Visibility in MySQL Based on Manufacturer Region Settings?

CASE 또는 IF/ELSE를 사용하여 MySQL에서 제품 가시성 결정

제품 가시성이 제조업체가 정의한 지역에 따라 결정되는 시나리오에서는 상태(신품 또는 중고)와 제조업체가 지정한 해당 지역 설정을 기반으로 각 제품의 표시 영역을 동적으로 계산해야 할 수도 있습니다. 이는 MySQL에서 CASE 또는 IF/ELSE 문을 사용하여 달성할 수 있습니다.

CASE 문 접근 방식:

SELECT 
  t2.company_name,
  t2.expose_new,
  t2.expose_used,
  t1.title,
  t1.seller,
  t1.status,
  CASE status
      WHEN 'New' THEN t2.expose_new
      WHEN 'Used' THEN t2.expose_used
      ELSE NULL
  END as 'expose'
FROM
  `products` t1
JOIN manufacturers t2
  ON
    t2.id = t1.seller
WHERE
  t1.seller = 4238

이 쿼리에서 CASE 문은 상태를 평가합니다. 제품(새 제품 또는 중고 제품)을 확인하고 제조업체의 노출_새 또는 노출_사용 설정에 따라 적절한 노출 값을 조건부로 할당합니다. 결과는 각 제품에 대한 한 자리 '노출' 값으로, 가시 영역을 나타냅니다.

IF/ELSE 접근 방식:

IF/ELSE가 접근하는 동안 시도에 논리적 오류가 포함된 경우 수정된 버전은 다음과 같습니다.

SELECT 
  t2.company_name,
  t2.expose_new,
  t2.expose_used,
  t1.title,
  t1.seller,
  t1.status,
  IF(status = 'New', t2.expose_new, IF(status = 'Used', t2.expose_used, NULL)) as 'expose'
FROM
  `products` t1
JOIN manufacturers t2
  ON
    t2.id = t1.seller
WHERE
  t1.seller = 4238

이 수정된 쿼리에서 IF/ELSE 문은 제품의 상태와 제조사의 노출 설정에 따라 노출값을 조건부로 부여합니다. 결과는 CASE 문 접근 방식과 동일하며 각 제품에 '노출' 값을 제공합니다.

MySQL의 CASE 문이나 IF/ELSE 문을 활용하면 기반으로 제품의 가시 영역을 효과적으로 계산할 수 있습니다. 제조업체가 지정한 규칙에 따라 제품 정보를 동적 및 조건부로 표시할 수 있습니다.

위 내용은 제조업체 지역 설정을 기반으로 MySQL에서 제품 가시성을 어떻게 동적으로 결정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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