> 백엔드 개발 > PHP 문제 > PHP 코드를 사용하여 두 테이블의 관련 쿼리 표시 구현

PHP 코드를 사용하여 두 테이블의 관련 쿼리 표시 구현

PHPz
풀어 주다: 2023-03-29 10:34:50
원래의
974명이 탐색했습니다.

많은 애플리케이션에서 필요한 정보를 얻으려면 여러 데이터베이스 테이블에서 데이터를 검색해야 합니다. 이 경우 두 테이블 간의 조인 쿼리는 필요한 데이터를 쿼리하는 매우 강력한 도구로 사용될 수 있습니다. 이 기사에서는 PHP 코드를 사용하여 두 테이블의 관련 쿼리 표시를 구현하는 방법을 소개합니다.

먼저, 관련 데이터베이스 테이블 쌍을 생성해야 합니다. 간단한 전자상거래 웹사이트의 시나리오를 시뮬레이션해 보겠습니다. 첫 번째 테이블은 판매 가능한 모든 제품이 포함된 products 테이블입니다. 두 번째 테이블은 기존 주문의 세부정보가 포함된 orders 테이블입니다. 두 테이블 간의 연결은 products.id 필드와 orders.product_id 필드 간의 연결입니다. products 表,它包含所有可供销售的产品。第二张表是 orders 表,它包含已存在订单的详细信息。两张表之间的关联是 products.id 字段和 orders.product_id 字段之间的关联。

products 表中,我们需要添加以下几个字段:

CREATE TABLE products (
    id INT PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) NOT NULL,
    price DECIMAL(10, 2) NOT NULL
);
로그인 후 복사

orders 表中,我们需要添加以下几个字段:

CREATE TABLE orders (
    id INT PRIMARY KEY AUTO_INCREMENT,
    product_id INT NOT NULL,
    customer_name VARCHAR(255) NOT NULL,
    quantity INT NOT NULL,
    total_price DECIMAL(10, 2) NOT NULL,
    order_date DATE NOT NULL,

    FOREIGN KEY (product_id) REFERENCES products(id)
);
로그인 후 복사

现在,在我们的数据库中有两张相关联的表。接下来是如何使用 PHP 代码来查询这些数据并将它们显示在网页上的过程。

首先,我们需要连接到数据库。使用以下代码连接到您的数据库:

// 使用 mysqli 连接到数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "database_name";

$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}
로그인 후 복사

现在我们已经成功连接到数据库,接下来是关键部分:查询两张表并将它们结合在一起显示出来。使用以下代码来查询两张表并将它们结合在一起显示:

$sql = "SELECT products.name, products.price, orders.customer_name, orders.quantity, orders.total_price, orders.order_date
        FROM products
        INNER JOIN orders
        ON products.id = orders.product_id";

$result = $conn->query($sql);

if ($result->num_rows > 0) {
    // 输出数据
    while($row = $result->fetch_assoc()) {
        echo "产品名称: " . $row["name"] . "<br>";
        echo "价格: " . $row["price"] . "<br>";
        echo "客户姓名: " . $row["customer_name"] . "<br>";
        echo "数量: " . $row["quantity"] . "<br>";
        echo "总价: " . $row["total_price"] . "<br>";
        echo "订单日期: " . $row["order_date"] . "<br><br>";
    }
} else {
    echo "没有数据!";
}
로그인 후 복사

在上面的代码中,我们使用了 SELECT 语句和 INNER JOIN 来结合两张表。使用这个查询,我们可以从 products 表和 orders 表中检索数据,并根据它们之间的关联将它们结合在一起。我们使用 mysqli_fetch_assoc()

products 테이블에 다음 필드를 추가해야 합니다.

rrreee

orders 테이블에 다음 필드를 추가해야 합니다. 🎜rrreee🎜이제, 우리 데이터베이스에는 두 개의 관련 테이블이 있습니다. 다음은 PHP 코드를 사용하여 이 데이터를 쿼리하고 웹 페이지에 표시하는 프로세스입니다. 🎜🎜먼저 데이터베이스에 연결해야 합니다. 다음 코드를 사용하여 데이터베이스에 연결하세요. 🎜rrreee🎜 이제 데이터베이스에 성공적으로 연결되었으므로 중요한 부분이 나옵니다. 두 테이블을 쿼리하고 결합하여 표시하는 것입니다. 다음 코드를 사용하여 두 테이블을 쿼리하고 결합하여 표시합니다. 🎜rrreee🎜위 코드에서는 SELECT 문과 INNER JOIN을 사용하여 두 테이블을 결합했습니다. 장 테이블. 이 쿼리를 사용하면 products 테이블과 orders 테이블에서 데이터를 검색하고 이들 사이의 연관성을 기반으로 함께 조인할 수 있습니다. mysqli_fetch_assoc() 함수를 사용하여 데이터베이스에서 검색된 데이터를 반복하고 결과를 웹 페이지에 출력합니다. 🎜🎜이제 PHP 코드를 사용하여 두 테이블 간의 상관 관계 쿼리를 성공적으로 구현하고 그 결과를 웹 페이지에 표시했습니다. 🎜

위 내용은 PHP 코드를 사용하여 두 테이블의 관련 쿼리 표시 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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