PHP를 MySQL에 연결하는 데는 세 가지 API 인터페이스가 있습니다. 즉, PHP의 MySQL 확장, PHP의 mysqli 확장 및 PHP 데이터 개체(PDO)는 다양한 시나리오에서 선택을 준비하기 위한 위의 세 가지 연결 방법을 요약한 것입니다. 해결책.
MySQL Extension for PHP는 PHP 애플리케이션이 MySQL 데이터베이스와 상호 작용할 수 있도록 설계 및 개발된 초기 확장입니다. MySQL 확장은 절차 지향 인터페이스를 제공하며 MySQL 4.1.3 이하 버전용으로 설계되었습니다. 따라서 이 확장은 MySQL 4.1.3 또는 최신 데이터베이스 서버와 상호 작용할 수 있지만 이후 MySQL 서버에서 제공되는 일부 기능은 지원하지 않습니다. 너무 오래되고 안전하지 않기 때문에 최신 mysqli로 완전히 대체되었습니다.
PHP의 mysqli 확장. 때때로 이를 MySQL 향상 확장이라고 부르며, 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 확장
PDO | PHP의 mysql 확장 |
| PHP 버전 소개 | 5.0
5.0 | 3.0 이전 |
| PHP5를 사용합니다. |
MySQL 새 프로젝트의 권장 사용 수준 | Recommendation - Preferred | Recommendation | 권장되지 않음 |
API 문자 집합 지원 | 예 | 예 | 안돼 |
서버 측 준비 문 지원 | Yes | Yes | No |
클라이언트 준비 문 지원 | No | Yes | No |
저장 프로시저 지원 | 예 | 그렇습니다 | 아니요 |
다양한 문장 실행 지원 | 예 | 대부분 | 아니요 |
MySQL 4.1 이상의 모든 기능을 지원하는지 여부 | 예 | 대부분 | 아니요 |
이 공식 결과에서 보세요 , msqli가 먼저 권장되고 그 다음 PDO가 권장됩니다. "folk"가 제공하는 결과 중 상당수는 PDO를 사용하는 경향이 있습니다. 왜냐하면 교차 데이터베이스의 장점이 없고 빠른 읽기 및 쓰기 속도의 특성을 갖기 때문입니다. |
1. PHP 및 Mysql 확장(이 확장은 PHP 5.5.0부터 사용되지 않으며 향후 제거될 예정). 데이터베이스에 연결하는 PHP의 기본 방식은 | <?php
$mysql_conf = array(
'host' => '127.0.0.1:3306',
'db' => 'test',
'db_user' => 'root',
'db_pwd' => 'root',
);
$mysql_conn = @mysql_connect($mysql_conf['host'], $mysql_conf['db_user'], $mysql_conf['db_pwd']);
if (!$mysql_conn) {
die("could not connect to the database:\n" . mysql_error());//诊断连接错误
}
mysql_query("set names 'utf8'");//编码转化
$select_db = mysql_select_db($mysql_conf['db']);
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. PHP 및 Mysqli 확장입니다. 프로세스 지향, 객체 지향 | <?php
$mysql_conf = array(
'host' => '127.0.0.1:3306',
'db' => 'test',
'db_user' => 'root',
'db_pwd' => 'joshua317',
);
$mysqli = @new mysqli($mysql_conf['host'], $mysql_conf['db_user'], $mysql_conf['db_pwd']);
if ($mysqli->connect_errno) {
die("could not connect to the database:\n" . $mysqli->connect_error);//诊断连接错误
}
$mysqli->query("set names 'utf8';");//编码转化
$select_db = $mysqli->select_db($mysql_conf['db']);
if (!$select_db) {
die("could not connect to the db:\n" . $mysqli->error);
}$sql = "select uid from user where name = 'joshua';";
$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(
'host' => '127.0.0.1:3306',
'db' => 'test',
'db_user' => 'root',
'db_pwd' => 'joshua317',
);
$pdo = new PDO("mysql:host=" . $mysql_conf['host'] . ";dbname=" . $mysql_conf['db'], $mysql_conf['db_user'], $mysql_conf['db_pwd']);//创建一个pdo对象
$pdo->exec("set names 'utf8'");
$sql = "select * from user where name = ?";
$stmt = $pdo->prepare($sql);
$stmt->bindValue(1, 'joshua', 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 관련 지식을 더 보려면 php 중국어 웹사이트를 방문하세요! |
위 내용은 PHP에서 데이터베이스에 연결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!