>  기사  >  데이터 베이스  >  MySQL에서 동적 SQL을 사용하여 유사한 접두사가 있는 열에서 데이터를 선택하는 방법은 무엇입니까?

MySQL에서 동적 SQL을 사용하여 유사한 접두사가 있는 열에서 데이터를 선택하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-03 08:38:021028검색

How to Select Data from Columns with Similar Prefixes using Dynamic SQL in MySQL?

와일드카드 열 선택을 위한 동적 SQL

질문:

데이터베이스 테이블이 있다고 가정합니다. "Fruit" 및 "Vegetable"과 같은 유사한 접두사를 공유하는 여러 열이 있습니다. 각 열 이름을 수동으로 지정하지 않고 특정 단어로 시작하는 모든 열에서 데이터를 효율적으로 선택할 수 있는 방법은 무엇입니까?

예:

다음 테이블 구조를 고려하세요.

<code class="markdown">Foods | Fruit | Vegetable
----------------------
Apples | Banana | Carrots
Pears | Grapes | Potatoes
Oranges | Lemon | Tomatoes</code>

이름이 "Vegetable"로 시작하는 모든 열을 선택하려고 합니다.

답변:

SELECT와 같은 MySQL 쿼리에서 직접 와일드카드 대체 야채 %는 지원되지 않습니다. 이 기준을 충족하는 모든 열을 동적으로 선택하려면 데이터베이스 스키마에서 얻은 정보를 기반으로 SQL 쿼리를 작성할 수 있습니다. 해결 방법은 다음과 같습니다.

<code class="sql">SELECT COLUMN_NAME
FROM INFORMATION_SCHEMA.COLUMNS
WHERE table_name = 'Foods'
  AND table_schema = 'YourDB'
  AND column_name LIKE 'Vegetable%'</code>

이 쿼리는 Foods 테이블에서 "Vegetable"로 시작하는 모든 열 이름을 검색합니다. 그런 다음 이 정보를 사용하여 원하는 열에서 데이터를 선택하는 두 번째 쿼리를 동적으로 구성할 수 있습니다.

<code class="php">$columnList = mysql_query($columnsQuery);
$columnArray = array();
while ($row = mysql_fetch_assoc($columnList)) {
  array_push($columnArray, $row['COLUMN_NAME']);
}
$columns = implode(",", $columnArray);

$query = "SELECT " . $columns . " FROM Foods";</code>

이 쿼리를 실행하면 이름이 "Vegetable"로 시작하는 열에서 모든 데이터를 검색할 수 있습니다. 단일 패스.

위 내용은 MySQL에서 동적 SQL을 사용하여 유사한 접두사가 있는 열에서 데이터를 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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