쿼리 결과를 기반으로 사용자 정의 변수를 할당하면 데이터베이스 조작 기능이 향상됩니다. 이 기사에서는 중첩된 쿼리를 사용하지 않고 MySQL에서 이를 달성하는 방법을 살펴봅니다.
일반적인 믿음과는 달리 사용자 변수 할당은 쿼리에 직접 통합될 수 있습니다. SET 문의 대입 연산자는 = 또는 :=입니다. 그러나 =는 비교용으로 예약되어 있으므로 다른 문 내에서는 :=를 사용해야 합니다.
이 기술을 설명하기 위해 USER와 GROUP이 고유하다고 가정해 보겠습니다. 다음 쿼리 시퀀스는 기능을 보여줍니다.
SET @user := 123456; SELECT @group := `group` FROM USER WHERE user = @user; SELECT * FROM USER WHERE `group` = @group;
다음 데이터가 포함된 샘플 테이블 사용:
CREATE TABLE user (`user` int, `group` int); INSERT INTO user VALUES (123456, 5); INSERT INTO user VALUES (111111, 5);
쿼리는 다음을 생성합니다. 결과:
+--------+-------+ | user | group | +--------+-------+ | 123456 | 5 | | 111111 | 5 | +--------+-------+
대안으로 다음 구문을 사용할 수 있습니다.
SET @user := 123456; SELECT `group` FROM user LIMIT 1 INTO @group; SELECT * FROM user WHERE `group` = @group;
위 내용은 중첩 쿼리를 사용하지 않고 MySQL의 쿼리 결과에서 사용자 변수를 할당하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!