>백엔드 개발 >PHP 튜토리얼 >MySQL-PHP 코드를 현대화하는 방법: 더 이상 사용되지 않는 `mysql_*` 함수를 준비된 명령문 및 PDO로 교체합니까?

MySQL-PHP 코드를 현대화하는 방법: 더 이상 사용되지 않는 `mysql_*` 함수를 준비된 명령문 및 PDO로 교체합니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-26 18:25:03703검색

How to Modernize Your MySQL-PHP Code: Replacing Deprecated `mysql_*` Functions with Prepared Statements and PDO?

더 이상 사용되지 않는 mysql_* 함수로 기존 MySQL-PHP 코드 재작성

PHP가 발전함에 따라 mysql_* 명령을 포함한 특정 기능이 더 이상 사용되지 않습니다. 보안과 안정성을 강화하려면 이러한 명령을 준비된 명령문과 PDO로 바꿔야 합니다.

키 대체:

  • mysql_connect를 PDO::__construct()로 바꾸세요. .
  • mysql_select_db를 PDO 연결 문자열의 데이터베이스 이름 설정으로 바꿉니다(예: mysql:host=127.0.0.1;dbname=people.

코드 샘플:

<code class="php"> // Old deprecated code
$db = new dbConn('127.0.0.1', 'root', 'pass', 'people', 'animals');

 // New PDO code
$db = new PDO('mysql:host=127.0.0.1;dbname=people;charset=UTF-8', 'root', 'pass');</code>

추가 고려 사항:

  • 생성자 및 소멸자: __construct() 및 __destruct() 함수는 내부적으로 연결 및 닫기를 처리하므로 PDO에 필요합니다.
  • 데이터베이스 선택: 데이터베이스 선택이 이제 PDO 연결 문자열에 포함됩니다. 연결 문자열에 dbname 매개 변수를 사용하여 원하는 데이터베이스를 지정합니다.

예제 클래스:

다음 예제 클래스는 다음을 사용하여 selectDb 메서드를 다시 작성하는 방법을 보여줍니다. PDO:

<code class="php">class DB
{
    private $pdo;

    public function __construct($host, $db, $user, $pass)
    {
        // Establish PDO connection
        $this->pdo = new PDO("mysql:host=$host;dbname=$db;charset=UTF-8", $user, $pass);
    }

    public function selectDatabase($dbName)
    {
        // No longer required with PDO
    }
}</code>

결론:

더 이상 사용되지 않는 mysql_* 함수를 준비된 명령문 및 PDO로 대체함으로써 개발자는 데이터베이스를 단순화하는 동시에 코드의 보안과 안정성을 강화할 수 있습니다. 상호 작용.

위 내용은 MySQL-PHP 코드를 현대화하는 방법: 더 이상 사용되지 않는 `mysql_*` 함수를 준비된 명령문 및 PDO로 교체합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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