>데이터 베이스 >MySQL 튜토리얼 >SQL을 사용하여 Microsoft Access에서 Upserting을 어떻게 시뮬레이션할 수 있습니까?

SQL을 사용하여 Microsoft Access에서 Upserting을 어떻게 시뮬레이션할 수 있습니까?

DDD
DDD원래의
2025-01-19 20:21:12864검색

How Can I Simulate Upserting in Microsoft Access Using SQL?

Microsoft Access에서 Upsert 작업 시뮬레이션

일반적으로 테이블에 행을 삽입하고 업데이트하는 것은 두 가지 독립적인 프로세스입니다. 하지만 하나의 쿼리에서 두 작업을 모두 수행하려면 어떻게 해야 할까요? 이 작업을 흔히 "Upsert"라고 합니다.

Microsoft Access 2000 이상에서는 LEFT JOIN과 함께 UPDATE 쿼리를 사용하여 Upsert 작업을 시뮬레이션할 수 있습니다. 구문은 다음과 같습니다.

<code class="language-sql">UPDATE b
LEFT JOIN a ON b.id = a.id
SET a.f1 = b.f1, a.f2 = b.f2, a.f3 = b.f3;</code>

이 쿼리에서:

  • 테이블 "b"는 삽입하거나 업데이트하려는 새 데이터입니다.
  • 테이블 "a"는 작업하려는 기존 테이블입니다.
  • 왼쪽 조인을 사용하면 테이블 "a"에 존재하지 않는 모든 행이 자동으로 NULL 값으로 조인됩니다.

따라서 ID가 b.id인 행이 테이블 "a"에 존재하는 경우 해당 행은 테이블 "b"의 값으로 업데이트됩니다. 그렇지 않으면 새 행이 테이블 "a"에 삽입됩니다.

예:

다음 형식을 고려하세요.

<code>| 表 "a" | 表 "b" |
|---|---|
| ID | Field1 | ID | Field1 |
| 1 | ValueA1 | 1 | ValueB1 |
| 2 | ValueA2 | 2 | ValueB2 |
| 3 | ValueA3 | 3 | ValueB3 |
|   |         | 4 | ValueB4 |</code>

위의 UPDATE 쿼리를 실행하면 다음과 같은 업데이트된 테이블 "a"가 생성됩니다.

<code>| ID | Field1 |
|---|---|
| 1 | ValueB1 |
| 2 | ValueB2 |
| 3 | ValueB3 |
| 4 | ValueB4 |  **(ID = 4 的新行已插入)**</code>

위 내용은 SQL을 사용하여 Microsoft Access에서 Upserting을 어떻게 시뮬레이션할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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