> 데이터 베이스 > MySQL 튜토리얼 > MS Access에서 테이블 없는 UNION 쿼리를 수행하는 방법은 무엇입니까?

MS Access에서 테이블 없는 UNION 쿼리를 수행하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-12 09:25:43
원래의
865명이 탐색했습니다.

How to Perform a Table-less UNION Query in MS Access?

MS Access(Jet/ACE)의 테이블 없는 UNION 쿼리

Jet/ACE 데이터베이스 엔진을 사용하는 Microsoft Access에서 테이블 데이터 소스를 지정하지 않고 UNION 쿼리를 사용하려고 하면 오류가 발생할 수 있습니다. "쿼리 입력에는 하나 이상의 테이블이나 쿼리가 포함되어야 합니다."라는 오류 메시지가 나타납니다.

이 제한은 해당 데이터 소스의 필드가 사용되지 않는 경우에도 FROM 절에 하나 이상의 테이블 또는 쿼리에 대한 엔진 요구 사항에서 비롯됩니다. 이 문제를 극복하기 위해 항상 단일 행을 포함하는 가상 테이블을 사용할 수 있습니다.

가상 테이블 만들기

<code>Public Sub CreateDualTable()
    Dim strSql As String
    strSql = "CREATE TABLE Dual (id COUNTER CONSTRAINT pkey PRIMARY KEY);"
    Debug.Print strSql
    CurrentProject.Connection.Execute strSql
    strSql = "INSERT INTO Dual (id) VALUES (1);"
    Debug.Print strSql
    CurrentProject.Connection.Execute strSql

    strSql = "ALTER TABLE Dual" & vbNewLine & _
        vbTab & "ADD CONSTRAINT there_can_be_only_one" & vbNewLine & _
        vbTab & "CHECK (" & vbNewLine & _
        vbTab & vbTab & "(SELECT Count(*) FROM Dual) = 1" & vbNewLine & _
        vbTab & vbTab & ");"
    Debug.Print strSql
    CurrentProject.Connection.Execute strSql
End Sub</code>
로그인 후 복사

가상 테이블 사용

이제 가상 테이블을 사용하여 테이블 없는 UNION 쿼리를 생성할 수 있습니다.

<code>SELECT "foo" AS my_text
FROM Dual
UNION ALL
SELECT "bar"
FROM Dual;</code>
로그인 후 복사

대체 방법

또는 TOP 1 또는 WHERE 절과 함께 SELECT 문을 사용하여 결과 집합을 단일 행으로 제한할 수 있습니다.

검사 제약 조건은 ADO(CurrentProject.Connection.Execute)를 통해 실행되는 문에서만 사용할 수 있습니다. DAO(CurrentDb.Execute)는 검사 제약 조건 생성을 지원하지 않습니다.

위 내용은 MS Access에서 테이블 없는 UNION 쿼리를 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿