>  기사  >  데이터 베이스  >  WHERE IN 절을 사용하여 특정 순서로 행을 검색하는 방법은 무엇입니까?

WHERE IN 절을 사용하여 특정 순서로 행을 검색하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-26 15:31:30138검색

How to Retrieve Rows in a Specific Order Using the WHERE IN Clause?

WHERE IN 절을 사용하여 지정된 순서로 행 검색

WHERE IN 절을 사용하여 데이터를 쿼리할 때 행은 일반적으로 오름차순으로 반환됩니다. 조항에 지정된 필드를 기준으로 순서를 지정합니다. 그러나 WHERE 절에 나타나는 정확한 순서로 행을 검색해야 하는 경우가 있습니다.

이는 ORDER BY FIELD 함수를 사용하여 수행할 수 있습니다. FIELD 함수는 쉼표로 구분된 목록에서 지정된 값의 위치를 ​​반환합니다. 이 함수를 사용하면 WHERE IN 절에 나열된 값의 순서에 따라 행을 정렬할 수 있습니다.

예:

다음 쿼리를 고려하세요.

SELECT *
FROM table
WHERE id IN (118, 17, 113, 23, 72);

ID별로 오름차순으로 정렬된 행을 반환하는 쿼리입니다. IN 절에 지정된 순서대로 행을 검색하려면 다음과 같이 쿼리를 수정할 수 있습니다.

SELECT *
FROM table
WHERE id IN (118, 17, 113, 23, 72)
ORDER BY FIELD(id, 118, 17, 113, 23, 72)

ORDER BY FIELD 함수는 두 개의 매개 변수를 사용합니다.

  • 필드 정렬
  • 결과에 표시되는 순서대로 쉼표로 구분된 값 목록

이 경우에는 id 필드를 기준으로 행을 정렬하고, 쉼표로 구분된 목록의 값은 행이 반환되어야 하는 순서를 지정합니다.

ORDER BY FIELD 함수를 사용하면 WHERE IN 절에 지정된 정확한 순서로 행이 반환되도록 할 수 있습니다. .

위 내용은 WHERE IN 절을 사용하여 특정 순서로 행을 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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