> 백엔드 개발 > PHP 문제 > PHP에서 mysql과 mysqli의 차이점은 무엇입니까?

PHP에서 mysql과 mysqli의 차이점은 무엇입니까?

青灯夜游
풀어 주다: 2023-03-10 11:26:01
원래의
3158명이 탐색했습니다.

차이점: mysqli는 영구 연결 기능인 반면, mysql은 비영구 연결 기능입니다. Mysql은 연결될 때마다 연결 프로세스를 엽니다. mysqli는 항상 동일한 연결 프로세스를 사용하므로 서버 측의 부담을 크게 줄일 수 있습니다.

PHP에서 mysql과 mysqli의 차이점은 무엇입니까?

이 튜토리얼의 운영 환경: windows7 시스템, PHP7.1&&mysql8 버전, DELL G3 컴퓨터

1. mysql 및 mysqli 관련 개념:

1 Mysql과 mysqli는 모두 다음의 기능입니다. php Set은 mysql 데이터베이스와 거의 관련이 없습니다.

2. php5 버전 이전에는 mysql 데이터베이스를 구동하기 위해 일반적으로 php의 mysql 함수를 사용했는데, 이는 프로세스 지향적인 mysql_query() 함수였습니다. 3. php5 버전 이후에는 mysqli의 함수 기능이 사용되었습니다. 즉, mysql_query()에 해당하는 것이 mysqli_query()인데, 이는 객체지향적이며 객체를 이용해 연산을 수행하는 기능이다. mysql 데이터베이스 구동

2. mysql과 mysqli 차이점:

mysqli는 영구 연결 기능인 반면, mysql은 비영구 연결 기능입니다.

mysql 연결: 두 번째 사용될 때마다 새로운 프로세스가 다시 열립니다.

mysqli 연결: 항상 동일한 프로세스를 사용합니다.

이점: 이는 서버 측의 부담을 크게 줄일 수 있습니다.

mysqli는 트랜잭션과 같은 일부 고급 작업을 캡슐화하고 DB 작업 프로세스에서 사용할 수 있는 다양한 방법도 캡슐화합니다.

3. mysql 및 mysqli 사용법:

1: mysql(절차 모드):

$conn = mysql_connect('localhost', 'user', 'password'); //连接mysql数据库  mysql_select_db('data_base'); 
 //选择数据库  
 $result = mysql_query('select * from data_base');//第二个可选参数,指定打开的连接  
 $row = mysql_fetch_row( $result ) ) //只取一行数据  
 echo $row[0]; //输出第一个字段的值  
로그인 후 복사

PS: mysqli는 절차 모드에서 작동하며 일부 함수는 mysqli_query(resource)와 같은 리소스를 지정해야 합니다. 식별자, SQL 문) 및 리소스 식별 매개 변수가 앞에 배치되고 mysql_query의 리소스 식별(SQL 문, '리소스 식별')은 선택 사항이며 기본값은 마지막으로 열린 연결 또는 리소스입니다.

2.mysqli(개체 모드):  

$conn = new mysqli('localhost', 'user', 'password','data_base');  //要使用new操作符,最后一个参数是直接指定数据库  //假如构造时候不指定,那下一句需要$conn -> select_db('data_base')实现  $result = 
 $conn -> query( 'select * from data_base' );  
 $row = result -> fetch_row(); //取一行数据  
 echo row[0]; //输出第一个字段的值
로그인 후 복사

new mysqli('localhost', usenamer', 'password', 'databasename');를 사용할 때 오류를 보고하며 프롬프트는 다음과 같습니다.

Fatal error: Class 'mysqli' not found in ...
로그인 후 복사

일반적으로 mysqli 클래스는 기본적으로 켜져 있지 않기 때문에 켜져 있지 않습니다. , php.ini는 win에서 변경해야 합니다. php_mysqli.dll 앞의 ;를 제거하고 Linux에서 mysqli를 컴파일해야 합니다.

4.mysqli_connect()

1. mysqli를 사용하면 데이터베이스 이름을 mysqli_connect() 함수나 mysqli 생성자에 전달할 수 있습니다. mysqli_query() 또는 mysqli 객체 쿼리 query() 메서드를 호출할 때 식별자가 필요합니다.

추천 학습: "

PHP 비디오 튜토리얼

"

위 내용은 PHP에서 mysql과 mysqli의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿