> 백엔드 개발 > PHP 문제 > PHP에서 필드 이름을 쿼리하는 방법

PHP에서 필드 이름을 쿼리하는 방법

PHPz
풀어 주다: 2023-04-10 10:10:53
원래의
887명이 탐색했습니다.

PHP를 사용하여 웹사이트를 개발하는 과정에서 데이터베이스의 다양한 필드 이름을 쿼리하는 것은 매우 일반적인 작업입니다. 페이지에 표시하기 위한 것이든 후속 데이터 처리를 위한 것이든 데이터베이스 테이블에서 필드 이름을 가져와야 합니다. 이 기사에서는 PHP를 사용하여 데이터베이스 테이블의 필드 이름을 쿼리하는 방법을 소개합니다.

  1. DESC 명령 사용
    DESC는 MySQL의 명령으로, 테이블 구조, 필드 등 테이블 관련 정보를 반환할 수 있습니다. DESC 명령을 사용하여 테이블의 모든 필드 이름을 얻을 수 있습니다. 구체적인 구현은 다음과 같습니다.
<?php
//连接数据库
$conn = mysqli_connect("localhost", "root", "123456", "test");
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}

$sql = "DESC users";
$result = mysqli_query($conn, $sql);

//循环输出结果,即所有字段名
while($row = mysqli_fetch_assoc($result)) {
    echo $row[&#39;Field&#39;] . "<br />";
}

mysqli_close($conn);
?>
로그인 후 복사

위 코드에서 DESC users 문은 사용자 테이블의 구조 정보인 mysqli_query( ) 함수는 SQL 문을 실행하는 데 사용되며, mysqli_fetch_assoc() 함수는 결과 집합에서 행을 연관 배열로 검색하는 데 사용됩니다. 연관 배열이 반환되므로 $row['Field']를 사용하여 필드 이름을 가져온 다음 출력할 수 있습니다.

  1. SHOW COLUMNS 명령 사용
    SHOW COLUMNS 명령은 테이블의 필드 이름을 쿼리하는 데에도 사용할 수 있으며 DESC 명령보다 더 간단하고 명확합니다. 구체적인 구현 코드는 다음과 같습니다.
<?php
//连接数据库
$conn = mysqli_connect("localhost", "root", "123456", "test");
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}

$sql = "SHOW COLUMNS FROM users";
$result = mysqli_query($conn, $sql);

//循环输出结果,即所有字段名
while($row = mysqli_fetch_assoc($result)) {
    echo $row[&#39;Field&#39;] . "<br />";
}

mysqli_close($conn);
?>
로그인 후 복사

위 코드에서 SHOW COLUMNS FROM users 문은 users 테이블의 모든 필드 정보를 가져오는 데 사용되고, mysqli_query() 함수는 SQL 문을 실행하는 데 사용되며, mysqli_fetch_assoc () 함수는 결과 집합에서 연관 배열로 행을 검색하는 데 사용됩니다. 마찬가지로 $row['Field']를 사용하여 필드 이름을 가져온 다음 출력할 수 있습니다.

  1. information_schema 데이터베이스 사용
    information_schema는 MySQL의 시스템 데이터베이스로, 데이터베이스, 테이블, 필드 등에 대한 많은 세부 정보를 포함합니다. information_schema 데이터베이스의 테이블을 쿼리하면 필드 이름을 포함하여 모든 테이블에 대한 관련 정보를 얻을 수 있습니다. 구체적인 구현 코드는 다음과 같습니다.
<?php
//连接数据库
$conn = mysqli_connect("localhost", "root", "123456", "test");
if (!$conn) {
    die("连接失败: " . mysqli_connect_error());
}

$sql = "SELECT COLUMN_NAME FROM information_schema.columns WHERE table_name = &#39;users&#39;";
$result = mysqli_query($conn, $sql);

//循环输出结果,即所有字段名
while($row = mysqli_fetch_assoc($result)) {
    echo $row[&#39;COLUMN_NAME&#39;] . "<br />";
}

mysqli_close($conn);
?>
로그인 후 복사

위 코드에서는 SELECT COLUMN_NAME FROM information_schema.columns WHERE table_name = 'users' 문을 사용하여 users 테이블의 모든 필드 정보를 가져오고, mysqli_query() 함수를 사용합니다. SQL 문을 실행하는 데 사용되며, mysqli_fetch_assoc() 함수는 결과 집합에서 연관 배열로 행을 검색하는 데 사용됩니다. 연관 배열이 반환되므로 $row['COLUMN_NAME']을 사용하여 필드 이름을 가져온 다음 출력할 수 있습니다.

요약:
위의 세 가지 방법을 사용하여 MySQL 테이블의 필드 이름을 쿼리할 수 있습니다. 그 중 information_schema 데이터베이스를 사용하면 모든 테이블의 필드 정보를 얻을 수 있어 보다 유연하지만 일정량의 성능이 소모됩니다. DESC 및 SHOW COLUMNS 명령을 사용하는 것은 상대적으로 더 간단하고 직접적이며 상대적으로 더 나은 성능을 제공합니다. 동시에 구현 과정에서 SQL 주입과 같은 보안 문제를 방지하는 데에도 주의를 기울여야 합니다.

위 내용은 PHP에서 필드 이름을 쿼리하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿