>  기사  >  백엔드 개발  >  PHP를 MySQL 데이터베이스에 연결하는 세 가지 방법에 대한 간략한 토론

PHP를 MySQL 데이터베이스에 연결하는 세 가지 방법에 대한 간략한 토론

青灯夜游
青灯夜游앞으로
2020-04-27 09:46:173711검색

이 글에서는 PHP가 MySQL 데이터베이스(mysql, mysqli, pdo)에 연결하는 세 가지 방법을 소개하고, mysql, mysqli, pdo의 세 가지 방법을 기반으로 PHP가 MySQL 데이터베이스에 연결하는 관련 운용 기술과 주의사항을 분석한다. 그리고 예제 형태의 pdo. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.

PHP를 MySQL 데이터베이스에 연결하는 세 가지 방법에 대한 간략한 토론

PHP를 MySQL에 연결하는 데는 세 가지 API 인터페이스가 있습니다. 즉, PHP의 MySQL 확장, PHP의 mysqli 확장, PHP Data Object(PDO) 다음은 다양한 애플리케이션을 준비하기 위한 위의 세 가지 연결 방법을 요약한 것입니다. . 시나리오에 따라 가장 적합한 솔루션을 선택하세요.

PHP용 MySQL 확장은 PHP 애플리케이션이 MySQL 데이터베이스와 상호 작용할 수 있도록 설계 및 개발된 초기 확장입니다. MySQL 확장은 절차 지향 인터페이스를 제공하며 MySQL 4.1.3 이하 버전용으로 설계되었습니다. 따라서 이 확장은 MySQL 4.1.3 또는 최신 데이터베이스 서버와 상호 작용할 수 있지만 이후 MySQL 서버에서 제공되는 일부 기능은 지원하지 않습니다. 너무 오래되고 안전하지 않기 때문에 최신 mysqli로 완전히 대체되었습니다.

우리가 때때로 MySQL 향상 확장이라고 부르는 PHP의 mysqli 확장은 MySQL 4.1.3 또는 최신 버전의 새로운 고급 기능을 사용하는 데 사용할 수 있습니다. . 특징으로는 객체지향 인터페이스, 준비된 문 지원, 다중 문 실행 지원, 트랜잭션 지원, 향상된 디버깅 기능, 임베디드 서비스 지원, SQL 인젝션 문제를 완벽하게 해결하는 전처리 방법 등이 있습니다. 그러나 mysql 데이터베이스만 지원한다는 단점도 있습니다. 다른 데이터베이스를 운영하지 않는다면 의심할 여지없이 이것이 최선의 선택입니다.

PDO는 PHP Data Objects의 약어로, PHP 애플리케이션의 데이터베이스 추상화 계층 사양입니다. PDO는 PHP 애플리케이션이 연결하려는 특정 데이터베이스 서버 시스템 유형을 신경 쓰지 않도록 통일된 API 인터페이스를 제공합니다. 즉, PDO의 API를 사용하면 Oracle에서 MySQL로 등 필요할 때마다 데이터베이스 서버를 원활하게 전환할 수 있습니다. , 약간의 PHP 코드만 수정하면 됩니다. 그 기능은 JDBC, ODBC, DBI 등의 인터페이스와 유사합니다. 마찬가지로 SQL 주입 문제도 해결하고 보안도 좋습니다. 그러나 일부 다중 문 실행 쿼리는 지원되지 않는다는 단점도 있습니다(그러나 이러한 상황은 드뭅니다).

공식 기사에서는 다음 세 가지 항목을 비교합니다.

PHP의 mysqli 확장PDOPHP의 mysql 확장PHP 버전 소개 5.0 5.0 3.0 이전 PHP5를 사용합니다. MySQL 새 프로젝트의 권장 사용 수준Recommendation - PreferredRecommendation권장되지 않음API 문자 집합 지원예예 안돼서버 측 준비 문 지원YesYesNo클라이언트 준비 문 지원NoYesNo저장 프로시저 지원예그렇습니다 아니요다양한 문장 실행 지원 예 대부분 아니요 MySQL 4.1 이상의 모든 기능을 지원하는지 여부 예 대부분 아니요 1. PHP 및 Mysql 확장
<?php
$mysql_conf = array(
  &#39;host&#39;  => &#39;127.0.0.1:3306&#39;, 
  &#39;db&#39;   => &#39;test&#39;, 
  &#39;db_user&#39; => &#39;root&#39;, 
  &#39;db_pwd&#39; => &#39;root&#39;, 
  );
$mysql_conn = @mysql_connect($mysql_conf[&#39;host&#39;], $mysql_conf[&#39;db_user&#39;], $mysql_conf[&#39;db_pwd&#39;]);
if (!$mysql_conn) {
  die("could not connect to the database:\n" . mysql_error());//诊断连接错误
}
mysql_query("set names &#39;utf8&#39;");//编码转化
$select_db = mysql_select_db($mysql_conf[&#39;db&#39;]);
if (!$select_db) {
  die("could not connect to the db:\n" . mysql_error());
}
$sql = "select * from user;";
$res = mysql_query($sql);
if (!$res) {
  die("could get the res:\n" . mysql_error());
}
while ($row = mysql_fetch_assoc($res)) {
  print_r($row);
}
mysql_close($mysql_conn);
?>
2. Mysqli를 사용하여 프로세스 지향 및 객체 지향
<?php
$mysql_conf = array(
  &#39;host&#39;  => &#39;127.0.0.1:3306&#39;, 
  &#39;db&#39;   => &#39;test&#39;, 
  &#39;db_user&#39; => &#39;root&#39;, 
  &#39;db_pwd&#39; => &#39;joshua317&#39;, 
  );
$mysqli = @new mysqli($mysql_conf[&#39;host&#39;], $mysql_conf[&#39;db_user&#39;], $mysql_conf[&#39;db_pwd&#39;]);
if ($mysqli->connect_errno) {
  die("could not connect to the database:\n" . $mysqli->connect_error);//诊断连接错误
}
$mysqli->query("set names &#39;utf8&#39;;");//编码转化
$select_db = $mysqli->select_db($mysql_conf[&#39;db&#39;]);
if (!$select_db) {
  die("could not connect to the db:\n" . $mysqli->error);
}$sql = "select uid from user where name = &#39;joshua&#39;;";
$res = $mysqli->query($sql);
if (!$res) {
  die("sql error:\n" . $mysqli->error);
}
 while ($row = $res->fetch_assoc()) {
    var_dump($row);
  }
$res->free();
$mysqli->close();
?>
3. PHP 및 PDO 확장, 프로세스 지향 및 객체 지향
<?php
$mysql_conf = array(
  &#39;host&#39;  => &#39;127.0.0.1:3306&#39;, 
  &#39;db&#39;   => &#39;test&#39;, 
  &#39;db_user&#39; => &#39;root&#39;, 
  &#39;db_pwd&#39; => &#39;joshua317&#39;, 
  );
$pdo = new PDO("mysql:host=" . $mysql_conf[&#39;host&#39;] . ";dbname=" . $mysql_conf[&#39;db&#39;], $mysql_conf[&#39;db_user&#39;], $mysql_conf[&#39;db_pwd&#39;]);//创建一个pdo对象
$pdo->exec("set names &#39;utf8&#39;");
$sql = "select * from user where name = ?";
$stmt = $pdo->prepare($sql);
$stmt->bindValue(1, &#39;joshua&#39;, PDO::PARAM_STR);
$rs = $stmt->execute();
if ($rs) {
  // PDO::FETCH_ASSOC 关联数组形式
  // PDO::FETCH_NUM 数字索引数组形式
  while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
    var_dump($row);
  }
}
$pdo = null;//关闭连接
?>
PHP 중국어 웹사이트
이 공식 결과에서 보세요 , msqli가 먼저 권장되고 그 다음 PDO가 권장됩니다. "folk"가 제공하는 결과 중 상당수는 PDO를 사용하는 경향이 있습니다. 왜냐하면 교차 데이터베이스의 장점이 없고 빠른 읽기 및 쓰기 속도의 특성을 갖기 때문입니다. (이 확장은 PHP 5.5.0부터 사용되지 않으며 향후 제거될 예정입니다.) 데이터베이스에 연결하는 PHP의 기본 방식은 프로세스 중심입니다
더 많은 관련 지식을 보려면 를 주목하세요! !

위 내용은 PHP를 MySQL 데이터베이스에 연결하는 세 가지 방법에 대한 간략한 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 jb51.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제