>  기사  >  데이터 베이스  >  ## 하위 쿼리 없이 단일 작업으로 MySQL 행을 검색하고 업데이트하는 방법은 무엇입니까?

## 하위 쿼리 없이 단일 작업으로 MySQL 행을 검색하고 업데이트하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-25 02:26:30732검색

## How to Retrieve and Update MySQL Rows in a Single Operation Without Subqueries?

단일 작업으로 MySQL 행을 검색하고 업데이트하는 쿼리

SELECT 및 UPDATE 쿼리를 단일 작업으로 결합하면 효율성을 높이고 코드를 줄일 수 있습니다. 복잡성. 이 기사에서는 하위 쿼리를 사용하지 않고 이 목표를 달성하기 위한 솔루션을 살펴봅니다.

수수께끼

한 사용자가 다음 MySQL 쿼리를 결합하는 데 도움을 요청했습니다.

SELECT * FROM table WHERE group_id = 1013 and time > 100;
UPDATE table SET time = 0 WHERE group_id = 1013 and time > 100

주요 목표는 "시간" 필드를 0으로 업데이트하는 동시에 원하는 행을 검색하는 것이었습니다.

기발한 솔루션

솔루션에는 저장된 사용이 포함됩니다. 원하는 결과를 얻기 위한 절차. 저장 프로시저는 일련의 SQL 문을 캡슐화하며 하나의 단위로 실행될 수 있습니다.

"update_and_retrieve"라는 다음 프로시저가 작업을 수행합니다.

<code class="mysql">CREATE PROCEDURE update_and_retrieve(IN group_id INT, IN time INT)
BEGIN
    DECLARE updated_ids VARCHAR(255);

    UPDATE table SET time = 0 WHERE group_id = group_id AND time > time;

    SET updated_ids = (SELECT GROUP_CONCAT(fooid) FROM table WHERE group_id = group_id AND time > time);

    SELECT * FROM table WHERE fooid IN (updated_ids);
END;</code>

프로시저 호출

저장 프로시저를 호출하려면 다음 문을 실행하면 됩니다.

<code class="mysql">CALL update_and_retrieve(1013, 100);</code>

이렇게 하면 해당 행에 대해 "시간" 필드가 0으로 업데이트된 다음 업데이트된 행을 검색하여 표시합니다.

이점

이 접근 방식은 여러 가지 장점을 제공합니다.

  • 여러 작업을 단일 호출로 결합하여 불필요한 네트워크 왕복을 방지합니다.
  • 별도의 쿼리가 필요 없어 코드 구조가 단순화됩니다.
  • 데이터베이스 부하가 줄어들어 성능이 향상됩니다.

위 내용은 ## 하위 쿼리 없이 단일 작업으로 MySQL 행을 검색하고 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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