>  기사  >  백엔드 개발  >  데이터 파일에서 데이터베이스로: PHP에서 데이터베이스의 기본 작업

데이터 파일에서 데이터베이스로: PHP에서 데이터베이스의 기본 작업

王林
王林원래의
2023-05-11 17:22:361053검색

PHP는 널리 사용되는 서버 측 스크립팅 언어이며 웹 애플리케이션 개발을 처리하는 데 자주 사용됩니다. 많은 경우 PHP는 데이터베이스를 통해 많은 양의 데이터를 처리해야 하며, PHP에서의 데이터베이스 작업은 매우 중요합니다. 이 기사에서는 PHP의 데이터베이스 작업에 대한 기본 지식을 소개합니다.

  1. 데이터 저장: 파일 또는 데이터베이스?

PHP에서는 데이터를 파일이나 데이터베이스에 저장할 수 있습니다. 그렇다면 언제 어떤 옵션을 선택해야 할까요?

데이터의 양이 적고 자주 수정할 필요가 없는 경우에는 파일을 사용하는 것이 이해하고 처리하기 더 쉽기 때문에 더 나을 수도 있습니다. 그러나 데이터의 양이 많거나 빈번한 업데이트, 쿼리 및 기타 작업이 필요한 경우 데이터베이스를 사용하는 것이 더 적합합니다. 데이터베이스는 확장성과 성능이 뛰어나고 대용량 데이터와 빈번한 액세스를 더 잘 처리할 수 있기 때문입니다.

  1. 데이터베이스에 연결

PHP에서 데이터베이스 작업을 하려면 먼저 데이터베이스에 연결해야 합니다. 연결하기 전에 다음 매개변수를 결정해야 합니다.

  • 호스트 이름: 일반적으로 데이터베이스가 있는 로컬 호스트 또는 IP 주소입니다.
  • 사용자 이름: 데이터베이스의 로그인 이름입니다.
  • 비밀번호: 데이터베이스 로그인 비밀번호입니다.
  • 데이터베이스 이름: 연결할 데이터베이스의 이름입니다.

데이터베이스에 연결하기 위한 구문은 다음과 같습니다.

$conn = mysqli_connect($servername, $username, $password, $dbname);

그 중 $servername은 호스트 이름, $username은 사용자 이름, $password는 비밀번호, $dbname은 데이터베이스 이름을 나타냅니다. 이 문은 연결된 개체를 반환하고, 연결이 실패하면 false를 반환합니다.

  1. SQL문 실행

데이터베이스에 접속한 후 SQL문을 실행하여 데이터 삽입, 삭제, 수정, 조회 등 다양한 작업을 수행할 수 있습니다.

PHP에서는 mysqli_query() 함수를 사용하여 SQL 문을 실행할 수 있습니다. 이 함수에는 두 개의 매개변수가 필요합니다. 하나는 연결 개체이고 다른 하나는 실행할 SQL 문입니다. 예:

$sql = "SELECT * FROM users";
$result = mysqli_query($conn, $sql);

이 문은 모든 사용자에 대해 쿼리를 수행하고 결과를 $result 변수에 저장합니다. 명령문이 성공적으로 실행되면 $result에 쿼리 결과가 포함되고, 그렇지 않으면 false가 반환됩니다.

  1. 쿼리 결과 처리

쿼리 문을 실행한 후 일반적으로 결과를 처리해야 합니다. PHP에서 결과는 mysqli_fetch_array() 함수를 사용하여 배열 유형으로 변환해야 하는 리소스 유형일 수 있습니다.

while($row = mysqli_fetch_array($result)) {
    echo $row['username'] . "的邮箱地址是:" . $row['email'];
}

이 문은 쿼리 결과를 행별로 읽고 결과를 $row 배열에 저장합니다. 그런 다음 사용자 이름과 이메일 주소를 인쇄하십시오.

데이터를 업데이트하거나 삭제해야 하는 경우 mysqli_query() 함수를 사용하여 관련 작업을 수행할 수 있습니다. 예를 들어, 다음 명령문을 사용하여 "Tom"이라는 사용자를 삭제할 수 있습니다.

$sql = "DELETE FROM users WHERE username='Tom'";
mysqli_query($conn, $sql);

수정 또는 삭제 작업을 수행하려면 해당 권한이 있어야 한다는 점에 유의해야 합니다.

  1. 연결 종료

데이터베이스 작업을 완료한 후에는 데이터베이스 연결을 종료해야 합니다. mysqli_close() 함수를 사용하여 연결을 닫습니다.

mysqli_close($conn);
  1. 보안 문제

데이터베이스를 사용할 때 보안 문제에 주의해야 합니다. 예를 들어, SQL 주입 공격을 방지하려면 사용자가 입력한 데이터를 이스케이프하는 데 mysqli_real_escape_string() 함수를 사용해야 합니다.

$username = mysqli_real_escape_string($conn, $_POST['username']);

위 코드는 사용자가 입력한 사용자 이름을 이스케이프한 다음 이를 $username 변수에 저장합니다.

이 외에도 PHP 코드에서 데이터베이스에 대한 액세스를 제한해야 합니다. 예를 들어 특정 사용자만 특정 작업을 수행하도록 허용합니다.

위 내용은 데이터 파일에서 데이터베이스로: PHP에서 데이터베이스의 기본 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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