찾다
백엔드 개발PHP 튜토리얼PHP를 MySQL 데이터베이스에 연결하는 세 가지 방법에 대한 간략한 토론

이 글에서는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 脚本之家에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace("&nbsp;","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么查找字符串是第几位php怎么查找字符串是第几位Apr 22, 2022 pm 06:48 PM

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음