>데이터 베이스 >MySQL 튜토리얼 >MySQL SELECT 문 내에서 변수를 올바르게 사용하려면 어떻게 해야 합니까?

MySQL SELECT 문 내에서 변수를 올바르게 사용하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-12-16 14:13:09974검색

How Can I Correctly Use Variables Within a MySQL SELECT Statement?

SELECT 문 내에서 변수 사용

MySQL로 작업할 때 동일한 SELECT 내에서 변수를 정의하고 사용하려는 시나리오가 발생할 수 있습니다. 성명. 그러나 관련된 제한 사항을 인식하는 것이 중요합니다.

변수 할당 및 가독성

MySQL 문서에 따르면 일반적으로 변수에 값을 할당하는 것은 권장되지 않습니다. 사용자 변수를 읽고 동일한 명령문 내에서 읽으십시오. 사용자 변수와 관련된 표현식의 평가 순서는 정의되지 않으며 문의 요소에 따라 달라질 수 있습니다.

이는 다음 쿼리가 예상대로 작동하지 않을 수 있음을 의미합니다.

SELECT
    @z:=SUM(item),
    2*@z
FROM
    TableA;

이 경우 , 두 번째 열에 대해 NULL이 발생할 가능성이 높습니다.

왜 차이점이 있습니까? 프로시저?

사용자 변수 대신 저장 프로시저를 사용하는 다음 쿼리가 예상대로 작동하는 이유가 궁금할 것입니다.

SELECT
    @z:=someProcedure(item),
    2*@z
FROM
    TableA;

그 이유는 저장 프로시저 때문입니다. 프로시저는 사용자 변수와 다르게 평가됩니다. 저장 프로시저의 평가 순서는 정의되고 일관됩니다.

하위 쿼리 사용

원하는 기능을 얻으려면 하위 쿼리를 사용할 수 있습니다.

select @z, @z*2
from (SELECT @z:=sum(item)
      FROM TableA
     ) t;

이 접근 방식은 하위 쿼리를 사용하여 사용자 변수(@z)를 초기화한 다음 이를 기본 쿼리에서 참조합니다.

위 내용은 MySQL SELECT 문 내에서 변수를 올바르게 사용하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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