와일드카드 열 선택을 위한 동적 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!