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 중국어 웹사이트의 기타 관련 기사를 참조하세요!