PHP와 MySQL을 연동하여 게시글 저장 및 조회 기능을 구현하는 것은 게시판 시스템을 구축하는 데 있어 핵심적인 부분입니다. 이번 글에서는 PHP와 MySQL을 이용하여 게시글을 데이터베이스에 저장하고, 사용자가 저장된 게시글을 조회할 수 있는 기능을 만드는 방법을 설명하겠습니다. 데이터베이스와 PHP를 연동하는 기본적인 개념을 이해하고, 실제 코드 예제를 통해 게시글 저장과 조회 기능을 구현해보겠습니다.
1. PHP와 MySQL 연동을 위한 준비
PHP와 MySQL을 연동하기 위해서는 먼저 MySQL 데이터베이스를 설정하고, PHP에서 MySQL을 사용할 수 있도록 설정해야 합니다. 이를 위해서는 MySQL 서버와 PHP가 제대로 설치되어 있어야 합니다. 이 글에서는 MySQL 데이터베이스를 사용하여 게시판을 구축하는 방법을 다루므로, 데이터베이스와 테이블을 먼저 만들어야 합니다.
먼저, MySQL에서 사용할 데이터베이스와 게시글을 저장할 테이블을 생성하는 SQL 쿼리는 다음과 같습니다:
-- 데이터베이스 생성
CREATE DATABASE board_db;
-- 테이블 생성
USE board_db;
CREATE TABLE posts (
id INT AUTO_INCREMENT PRIMARY KEY,
title VARCHAR(255) NOT NULL,
content TEXT NOT NULL,
author VARCHAR(50) NOT NULL,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
위 쿼리에서는 'posts'라는 이름의 테이블을 생성하고, 각 게시글에 대한 제목(title), 내용(content), 작성자(author), 작성일(created_at)을 저장할 수 있는 필드를 설정했습니다.
2. 게시글 저장 기능 구현하기
이제 PHP를 사용하여 사용자가 입력한 게시글을 MySQL 데이터베이스에 저장하는 기능을 구현해보겠습니다. PHP에서는 MySQL에 연결하고, SQL 쿼리를 실행하는 데 `mysqli` 또는 `PDO`를 사용할 수 있습니다. 여기에서는 `mysqli`를 사용하여 데이터베이스에 연결하고, 데이터를 저장하는 예제를 살펴보겠습니다.
먼저, `config.php` 파일을 생성하여 MySQL 데이터베이스에 연결할 수 있는 정보를 설정합니다:
<?php
// config.php
$host = 'localhost'; // MySQL 서버 호스트
$username = 'root'; // MySQL 사용자 이름
$password = ''; // MySQL 비밀번호
$dbname = 'board_db'; // 사용할 데이터베이스 이름
// MySQL 연결
$conn = new mysqli($host, $username, $password, $dbname);
// 연결 확인
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
?>
위 코드에서 `$conn`은 MySQL 데이터베이스에 연결하는 객체입니다. 이제 사용자가 게시글을 작성하면 이를 `posts` 테이블에 저장할 수 있는 폼을 만들어야 합니다. HTML 폼을 작성하고, 그 데이터를 PHP로 처리하는 방식으로 진행합니다.
<!-- 게시글 작성 폼 -->
<form action="save_post.php" method="POST">
<label for="title">제목:</label>
<input type="text" id="title" name="title" required><br><br>
<label for="content">내용:</label>
<textarea id="content" name="content" required></textarea><br><br>
<label for="author">작성자:</label>
<input type="text" id="author" name="author" required><br><br>
<button type="submit">게시글 작성</button>
</form>
위 HTML 폼에서는 사용자가 게시글 제목, 내용, 작성자를 입력할 수 있습니다. 이 폼이 제출되면 `save_post.php` 파일로 데이터가 전송됩니다.
이제 `save_post.php` 파일에서 폼 데이터를 받아 MySQL 데이터베이스에 저장하는 코드를 작성해봅니다:
<?php
// save_post.php
include('config.php');
// 폼 데이터 받기
$title = $_POST['title'];
$content = $_POST['content'];
$author = $_POST['author'];
// SQL 쿼리 작성
$sql = "INSERT INTO posts (title, content, author) VALUES ('$title', '$content', '$author')";
// 쿼리 실행
if ($conn->query($sql) === TRUE) {
echo "새 게시글이 성공적으로 저장되었습니다.";
} else {
echo "오류: " . $sql . "<br>" . $conn->error;
}
// 연결 종료
$conn->close();
?>
위 PHP 코드에서는 사용자가 입력한 제목, 내용, 작성자 데이터를 `POST` 방식으로 받아 `INSERT INTO` SQL 쿼리를 통해 `posts` 테이블에 데이터를 삽입합니다. 데이터베이스에 성공적으로 저장되면 "새 게시글이 성공적으로 저장되었습니다."라는 메시지가 출력됩니다.
3. 게시글 조회 기능 구현하기
이제 MySQL에 저장된 게시글을 조회하는 기능을 구현해보겠습니다. 사용자가 게시글 목록을 볼 수 있도록, PHP에서 MySQL 데이터베이스에서 게시글을 조회하여 HTML로 출력하는 기능을 작성합니다.
먼저, `list_posts.php` 파일을 생성하여 MySQL에서 게시글 데이터를 조회하고 이를 화면에 출력하는 코드를 작성합니다:
<?php
// list_posts.php
include('config.php');
// SQL 쿼리 작성
$sql = "SELECT * FROM posts ORDER BY created_at DESC";
$result = $conn->query($sql);
// 게시글 목록 출력
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
echo "<h3>" . $row['title'] . "</h3>";
echo "<p>" . $row['content'] . "</p>";
echo "<p>작성자: " . $row['author'] . " | 작성일: " . $row['created_at'] . "</p><hr>";
}
} else {
echo "게시글이 없습니다.";
}
// 연결 종료
$conn->close();
?>
위 코드는 `posts` 테이블에서 모든 게시글을 조회하고, 각 게시글의 제목, 내용, 작성자, 작성일을 화면에 출력합니다. 게시글은 최신 작성일 순서대로 표시됩니다. 만약 게시글이 없다면 "게시글이 없습니다."라는 메시지를 출력합니다.
4. 마무리
이번 글에서는 PHP와 MySQL을 연동하여 게시글 저장 및 조회 기능을 구현하는 방법을 살펴보았습니다. PHP에서 MySQL에 연결하고, 데이터를 삽입하는 방법과 데이터를 조회하여 출력하는 방법을 배웠습니다. 이제 이를 바탕으로 더 많은 기능을 추가하고, 게시판을 완성해 나갈 수 있습니다. 예를 들어, 게시글 수정, 삭제 기능을 추가하거나, 게시글에 댓글을 달 수 있는 기능을 구현할 수 있습니다.
PHP와 MySQL의 연동은 다양한 웹 애플리케이션에서 중요한 역할을 합니다. 기본적인 게시판 시스템을 만들며 PHP와 MySQL의 연동에 대한 이해를 높여보세요.
'PHP로 웹사이트 만들기' 카테고리의 다른 글
9. PHP와 MySQL로 게시판 만들기: 로그인 및 회원가입 구현하기 (0) | 2025.01.30 |
---|---|
8. PHP와 MySQL로 게시판 만들기: 게시판에 사용자 등록 기능 추가하기 (0) | 2025.01.29 |
6. PHP와 MySQL로 게시판 만들기: 게시판 디자인 (0) | 2025.01.27 |
5. PHP와 MySQL로 게시판 만들기: PHP로 게시판 CRUD 기능 만들기 (0) | 2025.01.26 |
4. PHP와 MySQL로 게시판 만들기: PHP와 MySQL로 데이터베이스 설계하기 (0) | 2025.01.25 |