집 >데이터 베이스 >MySQL 튜토리얼 >단일 SQL SELECT 문에서 변수를 사용하면 종종 예기치 않은 결과가 반환되는 이유는 무엇입니까?
SELECT 문 내에서 변수 선언 및 활용
SQL에서 변수에 값을 할당하고 동일한 쿼리 내에서 해당 값을 검색하면 도전해 보세요. 다음 예를 고려하십시오.
SELECT @z:=SUM(item), 2*@z FROM TableA;
이 쿼리는 "item" 열의 합계를 계산하여 "@z"라는 변수에 저장하려고 시도합니다. 그런 다음 "@z" 값에 2를 곱합니다. 그러나 놀랍게도 두 번째 열은 항상 NULL을 반환합니다.
이는 MySQL 설명서에 사용자 변수에 값을 할당하고 변수 내에서 이를 읽는다고 명시적으로 명시되어 있기 때문에 발생합니다. 동일한 진술에 의존해서는 안됩니다. 이러한 표현식의 평가 순서는 정의되지 않으며 향후 릴리스에서 변경될 수 있습니다.
이를 더 자세히 설명하려면 대체 쿼리를 고려하세요.
SELECT @z:=someProcedure(item), 2*@z FROM TableA;
이 쿼리에서 "@z"는 프로시저 호출을 통해 값을 할당했습니다. 이 시나리오에서는 프로시저 호출이 변수 할당과 별도로 평가되므로 쿼리가 예상대로 작동합니다.
사용자 변수의 한계를 극복하기 위해 하위 쿼리를 활용하여 값을 할당하고 기본 쿼리 내에서 검색할 수 있습니다. query:
select @z, @z*2 from (SELECT @z:=sum(item) FROM TableA ) t;
이 하위 쿼리에서는 SELECT를 사용하여 "@z" 값이 할당됩니다. 그런 다음 기본 쿼리는 "@z"를 선택하고 필요한 계산을 수행합니다.
위 내용은 단일 SQL SELECT 문에서 변수를 사용하면 종종 예기치 않은 결과가 반환되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!