>백엔드 개발 >PHP 튜토리얼 >Mysqli-CURD 기본 동작 학습 및 개발 요약

Mysqli-CURD 기본 동작 학습 및 개발 요약

齐天大圣
齐天大圣원래의
2020-05-04 14:56:521601검색

PHP는 5.5부터 mysql 확장을 완전히 폐지했으며 대신 MySQLI 또는 PDO 사용을 공식적으로 권장합니다. 이 기사에서는 주로 mysqli의 몇 가지 기본 작업에 대해 설명합니다. mysqli를 사용하는 작성 스타일에는 객체 스타일과 기능적 스타일의 두 가지가 있습니다. 아래에서는 기능적 작성 스타일만 보여줍니다.

데이터베이스 연결

먼저 데이터베이스에 연결해야 합니다. 데이터에 연결하기 전에 일반적으로 데이터베이스 계정, 비밀번호, 포트 번호, 데이터베이스 이름을 준비해야 합니다.

네트워크 문제나 기타 이유로 인해 데이터베이스에 연결이 불가능한 경우가 많아 연결 실패에 대한 처리가 필요합니다.

<?php
// 数据库连接
$mysqli = mysqli_connect(
   &#39;localhost&#39;,
   &#39;root&#39;,
   &#39;&#39;,
   &#39;test&#39;
);

if (mysqli_connect_errno()) {
   throw new Exception(&#39;databases connect error:&#39;
       .mysqli_connect_error());
}

// ...一些数据库操作
// 关闭数据库资源
mysqli_close($mysqli);

문자 집합 설정

문자 집합을 설정하려면 mysqli_set_charset();

문자 집합을 사용하세요. 현재는 4바이트 길이의 문자를 지원하는 utf8mb4를 주로 사용합니다. 일부 이모티콘 문자를 지원합니다. 물론, 4바이트 문자를 지원할 필요가 없다면 utf8을 선택하면 됩니다. 공간이 더 많기 때문입니다.

mysqli_set_chartset($mysqli, &#39;utf8mb4&#39;);

데이터베이스 다시 선택

데이터베이스가 연결된 후 데이터베이스를 다시 선택할 수도 있습니다.

mysqli_select_db($mysqli, &#39;数据库名&#39;);

CURD Operation

mysqli_query(): 데이터베이스에서 작업을 수행하며 DDL, DQL 및 DML이 모두 지원됩니다.

mysqli_affected_rows(): 영향을 받은 레코드 행 수를 가져옵니다.

새 데이터 작업

mysqli_query($mysqli,
   "INSERT INTO users(username, age, sex)
               VALUES(&#39;周杰伦&#39;, 35, &#39;男&#39;),
                      (&#39;谢霆锋&#39;, 35, &#39;男&#39;)"
);

if (mysqli_affected_rows($mysqli) <= 0) {
   throw new Exception(&#39;databases insert error:&#39;
       . mysqli_error($mysqli));
}

데이터 작업 수정

여기서 주의할 점이 있는데, mysqli_affected_rows가 반환하는 값은 0입니다. 지난번과 똑같은 정보를 업데이트하는데, 이는 매우 흔한 일입니다. 예를 들어 수정 시 수정 버튼을 연속해서 여러 번 클릭하게 됩니다. 하지만 프로그램 코드에 문제가 있다는 뜻은 아닙니다. 따라서 신규 추가와 달리 0을 반환하는 것도 성공 상태여야 합니다. ╯)o).

mysqli_query($mysqli,
   "UPDATE users SET age=40 WHERE user_id = 1"
);

if (mysqli_affected_rows($mysqli) < 0) {
   throw new Exception(&#39;databases update error:&#39;
       . mysqli_error($mysqli));
}

쿼리 작업mysqli_query가 쿼리 문을 실행하면 함수는 mysqli_result 결과 집합을 반환합니다.

mysqli_fetch_all()은 결과 세트에서 모든 데이터를 가져옵니다. 이 함수의 두 번째 매개변수는 반환된 데이터의 형식을 지정할 수 있습니다. MYSQLI_NUM: 인덱스 배열을 반환합니다

MYSQLI_ASSOC: 연관 배열을 반환합니다.

MYSQLI_BOTH: 인덱스 배열과 연관 배열이 모두 있습니다

    그 후 결과 집합에 대한 작업이 완료되었습니다. 결과 집합 리소스를 삭제해야 합니다.
  • mysqli_query($mysqli,
       "Delete FROM users  WHERE user_id = 100"
    );
    
    if (mysqli_affected_rows($mysqli) <= 0) {
       throw new Exception(&#39;databases delete error:&#39;
           . mysqli_error($mysqli));
    }

    위는 Mysqli의 기본 동작, 개인의 실제 학습과 발전을 요약한 내용입니다. 토론 환영합니다!

위 내용은 Mysqli-CURD 기본 동작 학습 및 개발 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.