>데이터 베이스 >MySQL 튜토리얼 >우편번호 필터링 유무에 관계없이 SQL에서 중복 계좌 결제를 찾는 방법은 무엇입니까?

우편번호 필터링 유무에 관계없이 SQL에서 중복 계좌 결제를 찾는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-08 21:36:53697검색

How to Identify Duplicate Account Payments in SQL (With and Without ZIP Code Filtering)

SQL 데이터베이스에서 중복 계좌 결제 감지

이 가이드에서는 우편번호 고려 여부에 관계없이 SQL을 사용하여 단일 사용자의 중복 결제 기록을 찾아내는 방법을 보여줍니다.

중복 결제 확인(우편번호 제외)

다음 SQL 쿼리는 사용자가 동일한 계좌 번호와 관련된 여러 결제를 갖는 인스턴스를 효율적으로 식별합니다.

<code class="language-sql">SELECT
  user_id,
  COUNT(*) AS payment_count
FROM
  PAYMENT
GROUP BY
  account_no,
  user_id,
  payment_date
HAVING
  payment_count > 1;</code>

이 쿼리는 결제 기록을 account_no, user_id, payment_date별로 그룹화합니다. COUNT(*) 함수는 각 그룹의 지불액을 집계하고 HAVING 절은 결과를 필터링하여 2건 이상의 지불금(중복)이 있는 그룹만 표시합니다.

정확도 향상을 위해 우편번호 필터링 추가

우편번호가 다른 결제만 중복으로 간주되도록 하기 위해 쿼리를 수정합니다.

<code class="language-sql">SELECT
  user_id,
  account_no,
  payment_date,
  COUNT(*) AS payment_count
FROM
  (
    SELECT DISTINCT
      user_id,
      account_no,
      zip,
      payment_date
    FROM
      payment
  ) AS distinct_payments
GROUP BY
  user_id,
  account_no,
  payment_date
HAVING
  payment_count > 1;</code>

이 향상된 쿼리는 하위 쿼리(distinct_payments)를 활용하여 user_id, account_no, zippayment_date의 고유한 조합을 선택합니다. 그런 다음 기본 쿼리는 이러한 개별 레코드를 그룹화하고 계산하여 서로 다른 우편번호가 관련된 경우에만 중복 결제를 식별합니다. 이 접근 방식은 중복 결제에 대한 보다 정확한 분석을 제공합니다.

위 내용은 우편번호 필터링 유무에 관계없이 SQL에서 중복 계좌 결제를 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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