> 데이터 베이스 > MySQL 튜토리얼 > 스칼라가 아닌 하위 쿼리에서 SQL Server 테이블에 여러 행을 삽입하는 방법은 무엇입니까?

스칼라가 아닌 하위 쿼리에서 SQL Server 테이블에 여러 행을 삽입하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-05 14:11:40
원래의
686명이 탐색했습니다.

How to Insert Multiple Rows into a SQL Server Table from a Non-Scalar Subquery?

비 스칼라 하위 쿼리에서 테이블에 값 삽입

SQL Server에서 다음을 반환하는 하위 쿼리를 기반으로 테이블에 값 삽입 여러 결과가 어려울 수 있습니다. 다음 시나리오를 고려하십시오.

두 개의 테이블이 있습니다:

  • article
  • price

행을 삽입하고 싶습니다. group, idprice 열에 대한 특정 값이 포함된 price 테이블. 여기서 id 값은 다음과 같습니다. 기사에서 일치하는 ID를 선택하는 하위 쿼리에서 파생됨 table.

잘못된 접근 방식:

INSERT 문의 열 값으로 둘 이상의 결과가 포함된 하위 쿼리를 사용하려고 하면 오류가 발생할 수 있습니다. 다음과 같은 잘못된 SQL 문으로 입증됩니다.

INSERT INTO prices (group, id, price) 
VALUES (7, (select articleId from article WHERE name LIKE 'ABC%'), 1.50);
로그인 후 복사

올바름 해결 방법:

이 문제를 해결하려면 SELECT 문을 사용하여 원하는 값을 검색하고 이를 대상 테이블에 삽입하세요. groupprice 열에 대한 상수 값을 SELECT 문 내에서 직접 할당합니다.

insert into prices (group, id, price)
select 
    7, articleId, 1.50
from article where name like 'ABC%';
로그인 후 복사

이 문에서 하위 쿼리는 다음을 반환합니다. 지정된 이름 기준과 일치하는 기사 ID와 상수 값 7 및 1.50이 명시적으로 할당됩니다. 그룹가격 열입니다.

위 내용은 스칼라가 아닌 하위 쿼리에서 SQL Server 테이블에 여러 행을 삽입하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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