> 데이터 베이스 > MySQL 튜토리얼 > 헤더를 수동으로 지정하지 않고 MySQL 데이터에서 HTML 테이블을 동적으로 생성하려면 어떻게 해야 합니까?

헤더를 수동으로 지정하지 않고 MySQL 데이터에서 HTML 테이블을 동적으로 생성하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2024-12-04 02:11:10
원래의
211명이 탐색했습니다.

How Can I Dynamically Generate HTML Tables from MySQL Data Without Manually Specifying Headers?

MySQL과 PHP를 사용한 동적 HTML 테이블 생성

MySQL의 데이터로 채워진 HTML 테이블을 생성해야 하는 상황에 직면했을 수 있습니다. 그러나 테이블의 열 헤더는 자주 변경됩니다. 이러한 변경 사항을 반영하기 위해 코드를 수동으로 업데이트하는 것은 지루할 수 있습니다. 다음은 수동 헤더 지정 없이 MySQL 데이터에서 HTML 테이블을 동적으로 생성하는 솔루션입니다.

MySQLi 솔루션:

  1. 데이터베이스에 연결 : mysqli_connect()를 사용하여 MySQL 연결을 설정하고 charset.
  2. 테이블에 데이터를 출력하는 함수 정의: 데이터베이스 연결 및 테이블 이름을 입력으로 사용하는 함수를 생성합니다.
  3. 테이블 존재: SHOW TABLES 쿼리를 사용하여 입력 테이블이 존재하는지 확인합니다.
  4. 테이블 가져오기 data: SELECT * FROM $table을 사용하여 테이블의 모든 데이터를 검색합니다.
  5. 열 메타데이터 가져오기: fetch_fields()를 사용하여 열 정보를 가져옵니다.
  6. HTML 테이블 만들기: 로 테이블을 시작합니다. 태그를 추가한 다음 및 <일> 열 헤더 요소.
  7. 테이블 행 채우기: 데이터를 반복하고
  8. 그리고
    태그.
  9. 테이블 종료: <테이블> 태그.
  10. 예:

    <?php
    
    // Create a MySQLi connection
    $mysqli = new mysqli('localhost', 'username', 'password', 'database');
    
    function outputMySQLToHTMLTable(mysqli $mysqli, string $table)
    {
        // Check table existence
        $tableNames = array_column($mysqli->query('SHOW TABLES')->fetch_all(), 0);
        if (!in_array($table, $tableNames, true)) {
            throw new UnexpectedValueException('Unknown table name provided!');
        }
    
        // Fetch data and metadata
        $res = $mysqli->query('SELECT * FROM ' . $table);
        $data = $res->fetch_all(MYSQLI_ASSOC);
    
        echo '<table>';
        // Display table header
        echo '<thead>';
        echo '<tr>';
        foreach ($res->fetch_fields() as $column) {
            echo '<th>' . htmlspecialchars($column->name) . '</th>';
        }
        echo '</tr>';
        echo '</thead>';
    
        // Display table rows
        if ($data) {
            foreach ($data as $row) {
                echo '<tr>';
                foreach ($row as $cell) {
                    echo '<td>' . htmlspecialchars($cell) . '</td>';
                }
                echo '</tr>';
            }
        } else {
            echo '<tr><td colspan="' . $res->field_count . '">No records in the table!</td></tr>';
        }
        echo '</table>';
    }
    
    // Output the table
    outputMySQLToHTMLTable($mysqli, 'user');
    로그인 후 복사

    PDO 솔루션:

    PDO 접근 방식은 비슷하지만 테이블 이름 확인을 위해 fetchAll(PDO::FETCH_COLUMN)을 사용해야 하며 열 메타데이터용 getColumnMeta().

    이 접근 방식을 사용하면 코드에서 MySQL의 최신 테이블 구조를 기반으로 HTML 테이블을 동적으로 생성할 수 있으므로 수동 헤더 업데이트가 필요하지 않습니다.

    위 내용은 헤더를 수동으로 지정하지 않고 MySQL 데이터에서 HTML 테이블을 동적으로 생성하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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