차이점: mysqli는 영구 연결 기능인 반면, mysql은 비영구 연결 기능입니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!