>백엔드 개발 >PHP 문제 >PDO 데이터베이스를 이용하여 추가, 삭제, 수정, 확인하는 방법

PDO 데이터베이스를 이용하여 추가, 삭제, 수정, 확인하는 방법

PHPz
PHPz원래의
2023-04-24 10:49:461108검색

인터넷 애플리케이션 개발에서 데이터베이스는 모든 개발자가 마스터해야 하는 기술 중 하나입니다. 동적 웹 애플리케이션 개발에 가장 널리 사용되는 프로그래밍 언어인 PHP는 데이터베이스 작업을 처리하는 데에도 중요합니다. PDO는 PHP 확장에서 데이터베이스 작업을 처리하는 방법입니다. 다음은 PDO를 사용하여 기본적인 데이터베이스 추가, 삭제, 수정 및 쿼리 작업을 구현하는 방법을 소개합니다.

1. 데이터베이스에 연결

PHP를 사용하여 데이터베이스 작업을 수행하기 전에 데이터베이스에 연결해야 합니다. 데이터베이스에 연결하려면 연결해야 하는 데이터베이스 유형, 서버의 주소와 포트, 데이터베이스 이름, 사용자 이름, 비밀번호 및 기타 정보를 PDO에 알려야 합니다. 다음 코드를 사용하여 연결을 설정할 수 있습니다.

$dsn = 'mysql:host=localhost;dbname=testdb';  // 服务器地址和数据库名称
$username = 'root';  // 用户名
$password = '123456';  // 密码

try{
    $dbh = new PDO($dsn, $username, $password);  // 创建PDO对象
}catch(PDOException $e){
    echo 'Connection failed: ' . $e->getMessage();  // 连接失败时输出异常信息
}

$dsn 변수에는 데이터베이스 유형(mysql), 서버 주소(localhost) 및 연결할 데이터베이스 이름(testdb)이 포함되어야 합니다. 다른 유형의 데이터베이스에 연결하려면 필요에 따라 수정할 수 있습니다. $dsn 값. 데이터베이스에 성공적으로 연결되면 PDO 개체의 메서드를 호출하여 SQL 문을 실행할 수 있습니다.

2. 데이터 삽입

데이터베이스에 새 데이터를 삽입하는 것은 웹 애플리케이션 개발에서 매우 일반적인 작업입니다. 다음 코드는 PDO를 사용하여 새 데이터를 삽입하는 방법을 보여줍니다.

$sql = "INSERT INTO `users` (`username`, `password`) VALUES (?, ?)";
$stmt = $dbh->prepare($sql);  // 准备查询语句
$username = 'admin';  // 假设的用户名
$password = md5('123456');  // 假设的密码
$stmt->execute(array($username, $password)); // 执行查询语句

SQL 문을 실행하기 전에 먼저 쿼리 문 $sql을 준비해야 합니다. 쿼리 문의 물음표(?)는 자리 표시자이며 PDO는 prepare() 메서드의 두 번째 매개 변수에 따라 자리 표시자를 대체합니다. $stmt는 SQL 문의 준비 개체를 나타냅니다. Execute() 메서드를 호출하면 쿼리 문이 실행되고 자리 표시자가 실제 매개 변수 값으로 대체됩니다.

3. 데이터 쿼리

PDO를 사용하여 데이터베이스를 쿼리하는 것도 쉽습니다. PDO는 쿼리 문을 실행하고 쿼리 결과를 PDOStatement 개체에 저장하는 query() 메서드를 제공합니다. 다음은 PDO를 사용하여 데이터베이스를 쿼리하는 예입니다.

$sql = "SELECT * FROM `users` WHERE `username`=?";
$stmt = $dbh->prepare($sql);  // 准备查询语句
$username = 'admin';  // 假设要查询的用户名
if($stmt->execute(array($username))){  // 执行查询语句
    $rows = $stmt->fetchAll();  // 获取查询结果
    foreach($rows as $row){  // 遍历查询结果
        echo $row['id'] . ' ' . $row['username'] . ' ' . $row['password'] . '<br/>';
    }
}

위 코드에서 $sql 변수에는 users 테이블에서 사용자 이름 'admin'의 사용자 정보를 쿼리하는 SELECT 문이 저장됩니다. $stmt 변수는 쿼리 문의 준비된 개체를 가리킵니다. 쿼리 문을 실행하기 위해 Execution() 메서드를 호출할 때 자리 표시자의 실제 값을 배열을 통해 PDO에 전달합니다. 쿼리가 성공적으로 실행되면 fetchAll() 메서드를 사용하여 쿼리 결과를 가져오고 결과는 $rows 변수에 저장됩니다. foreach 루프를 사용하여 결과를 하나씩 출력할 수 있습니다.

4. 데이터 수정

데이터 삽입과 마찬가지로 데이터 수정도 일반적인 작업 중 하나입니다. 다음은 사용자의 비밀번호를 변경하는 예입니다.

$sql = "UPDATE `users` SET `password`=? WHERE `username`=?";
$stmt = $dbh->prepare($sql);  // 准备更新语句
$username = 'admin';  // 假设要更新的用户名
$new_password = md5('654321');  // 假设要更新的密码
if($stmt->execute(array($new_password, $username))){  // 执行更新语句
    echo 'Updated successfully.'; // 更新成功
}

위 코드에서 $sql 변수에는 사용자 테이블에서 'admin'이라는 사용자의 비밀번호를 업데이트하는 데 사용되는 UPDATE 문이 저장됩니다. 업데이트 문에서 SET 키워드 뒤의 비밀번호 필드는 수정할 새 비밀번호입니다. 동시에 WHERE 키워드는 업데이트해야 하는 사용자 레코드를 지정하는 데 사용됩니다. PDO가 업데이트 문을 실행하고 성공적으로 완료하면 프로그램은 업데이트가 성공했음을 나타내는 프롬프트 메시지를 출력합니다.

5. 데이터 삭제

데이터 삭제는 데이터 수정과 유사하며 일반적인 작업 중 하나입니다. 다음은 PDO를 통해 사용자 정보를 삭제하는 예입니다.

$sql = "DELETE FROM `users` WHERE `username`=?";
$stmt = $dbh->prepare($sql);  // 准备删除语句
$username = 'admin';  // 假设要删除的用户名
if($stmt->execute(array($username))){  // 执行删除语句
    echo 'Deleted successfully.'; // 删除成功
}

위 코드에서 $sql 변수에는 사용자 이름이 'admin'인 사용자 정보를 삭제하는 데 사용되는 DELETE 문이 저장됩니다. 업데이트 문과 유사하게 이 문은 WHERE 키워드를 사용하여 삭제해야 하는 사용자 레코드를 지정합니다. PDO가 삭제 문을 실행하고 성공적으로 완료하면 프로그램은 삭제가 성공했음을 나타내는 프롬프트 메시지를 출력합니다.

6. 요약

PDO를 데이터베이스 작업에 사용하려면 몇 가지 기술과 기법이 필요하지만, PDO의 기본 작업을 익히면 데이터베이스를 보다 효율적으로 추가, 삭제, 수정 및 쿼리할 수 있습니다. 이 글에서는 PDO를 사용하여 추가, 삭제, 수정, 쿼리 등의 기본 작업을 수행하는 방법을 소개합니다. 그러나 실제 개발에서는 개발 문제를 더 잘 해결하기 위해 보다 심층적인 PDO 작업 기술을 적용해야 합니다. 지속적인 학습과 실습을 통해 PDO의 고급 기술을 익히고 더 나은 웹 애플리케이션을 개발할 수 있습니다.

위 내용은 PDO 데이터베이스를 이용하여 추가, 삭제, 수정, 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.