MySQL에서 업데이트된 값 검색
MySQL에서 업데이트 작업을 수행할 때 일반적으로 영향을 받는 행 수가 기본적으로 반환됩니다. 그러나 업데이트된 값을 대신 검색하는 것이 바람직한 시나리오도 있습니다.
다음 쿼리를 고려하세요.
UPDATE item SET `score`=`score`+1 WHERE `id`=1
이 쿼리는 지정된 ID를 가진 항목의 점수를 높입니다. 기본적으로 이 쿼리를 실행한 결과는 영향을 받는 행 수(이 경우 1)입니다.
그러나 업데이트된 값을 검색하기 위해 저장 프로시저를 활용할 수 있습니다. 저장 프로시저를 사용하면 일련의 SQL 문을 단일 단위로 실행할 수 있으며 다음과 같이 정의할 수 있습니다.
<code class="sql">DELIMITER $$ -- Change DELIMITER in order to use ; withn the procedure CREATE PROCEDURE increment_score ( IN id_in INT ) BEGIN UPDATE item SET score = score + 1 WHERE id = id_in; SELECT score AS new_score FROM item WHERE id = id_in; END $$ -- Finish CREATE PROCEDURE statement DELIMITER ; -- Reset DELIMITER to standard ;</code>
이 저장 프로시저는 먼저 점수를 업데이트한 다음 이름이 지정된 출력 매개 변수에 새 값을 선택합니다. new_score. PHP에서는 이 저장 프로시저를 호출하고 다음과 같이 업데이트된 값을 검색할 수 있습니다.
<code class="php">$result = mysql_query("CALL increment_score($id)"); $row = mysql_fetch_array($result); echo $row['new_score'];</code>
저장 프로시저를 사용하면 단일 쿼리 내에서 업데이트 및 검색 작업을 모두 실행할 수 있으므로 쿼리를 수행하고 성능을 향상시킵니다.
위 내용은 MySQL 업데이트 작업 후 업데이트된 값을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!