찾다
PHP 프레임워크ThinkPHPThinkPHP6에서 AR을 사용하여 데이터베이스를 운영하는 방법

ThinkPHP6에서 AR을 사용하여 데이터베이스를 운영하는 방법

Jun 20, 2023 pm 01:18 PM
thinkphpar데이터베이스 작업

ThinkPHP는 풍부한 데이터베이스 운영 기능을 제공하는 인기 있는 PHP 개발 프레임워크입니다. 가장 일반적으로 사용되는 것은 Active Record 모드(이하 AR)입니다. AR 모드는 데이터베이스 테이블을 객체에 매핑하는 객체 지향 데이터베이스 운영 모드로, 데이터베이스를 보다 편리하고 빠르게 운영할 수 있습니다. 이번 글에서는 ThinkPHP6에서 AR을 활용하여 데이터베이스를 운영하는 방법을 소개하겠습니다.

  1. 데이터베이스 연결 구성

AR을 사용하기 전에 먼저 데이터베이스 연결 정보를 구성해야 합니다. config 디렉터리에 있는 Database.php 파일에 해당 데이터베이스 정보를 다음과 같이 입력합니다.

return [
    // 数据库类型
    'type'            => 'mysql',
    // 服务器地址
    'hostname'        => 'localhost',
    // 数据库名
    'database'        => 'test',
    // 用户名
    'username'        => 'root',
    // 密码
    'password'        => '',
    // 端口
    'hostport'        => '',
    // 数据库连接参数
    'params'          => [],
    // 数据库编码默认采用utf8
    'charset'         => 'utf8',
    // 数据库表前缀
    'prefix'          => '',
    // 数据库调试模式
    'debug'           => true,
];
  1. 모델 클래스 생성

ThinkPHP의 AR에서 각 테이블은 모델 클래스에 해당하므로 모델 클래스를 생성해야 합니다. 그리고 thinkModel 클래스를 상속받습니다. "users" 테이블을 예로 들어 Users 모델 클래스를 만듭니다.

namespace appmodel;

use thinkModel;

class Users extends Model
{
    // 定义用户表名
    protected $table = 'users';
}

모델 클래스에서는 테이블 이름, 기본 키, 필드 정보 등을 포함한 일부 데이터베이스 관련 정보를 정의할 수 있습니다. 그렇게 하면 작업이 더욱 편리해집니다.

  1. 데이터 쿼리

ThinkPHP의 AR에서는 데이터 쿼리가 매우 편리합니다. 모델 클래스에서 해당 메서드만 호출하면 됩니다. 예를 들어 모든 사용자 데이터(SELECT * FROM 사용자와 동일)를 쿼리하려면 다음 방법을 사용할 수 있습니다.

$users = Users::select();

모든 데이터를 쿼리하려면 select 메서드를 사용하세요. 기본값은 전체 테이블의 데이터를 쿼리하는 것입니다. . 또한 where 메소드를 사용하여 쿼리 조건을 지정하고 orderBy 메소드를 사용하여 정렬 조건을 지정할 수도 있습니다.

  1. 데이터 추가

데이터 추가도 똑같이 편리합니다. 모델 클래스에 인스턴스를 생성하고, 속성 값을 설정하고, save 메소드를 호출하기만 하면 됩니다. 예를 들어, 새로운 사용자 데이터를 추가하려면 다음 메서드를 사용할 수 있습니다.

$user = new Users;
$user->username = 'tom';
$user->email = 'tom@example.com';
$user->save();

위 코드에서는 먼저 Users 인스턴스를 만든 다음 사용자 이름과 이메일 속성 값을 설정하고 마지막으로 데이터베이스 중간에 데이터를 저장하는 save 메소드입니다.

  1. 데이터 업데이트

데이터 업데이트도 매우 간단합니다. 먼저 업데이트할 데이터를 쿼리한 다음 해당 속성 값을 설정하고 저장 메서드를 호출하면 됩니다. 예를 들어, ID가 1인 사용자의 사용자 이름을 수정하려면 다음 메서드를 사용할 수 있습니다.

$user = Users::get(1);
$user->username = 'jerry';
$user->save();

위 코드에서는 먼저 get 메서드를 통해 ID가 1인 사용자 데이터를 쿼리한 다음 사용자 이름을 수정합니다. 속성 값, 그리고 마지막으로 save 메소드가 호출되어 데이터를 데이터베이스에 업데이트합니다.

  1. 데이터 삭제

데이터 삭제도 매우 간단합니다. 모델 클래스에서 해당 메서드만 호출하면 됩니다. 예를 들어 ID가 1인 사용자 데이터를 삭제하려면 다음 메서드를 사용할 수 있습니다.

$user = Users::get(1);
$user->delete();

위 코드에서는 먼저 get 메서드를 통해 ID가 1인 사용자 데이터를 쿼리한 다음 삭제 메서드를 호출하여 데이터베이스에서 데이터를 삭제합니다.

결론적으로 AR 모드는 데이터베이스를 운영하는 매우 편리한 방법입니다. 데이터베이스 테이블을 객체에 매핑하여 데이터베이스를 보다 편리하고 빠르게 운영할 수 있습니다. ThinkPHP6에서는 AR의 사용도 매우 간단합니다. hinkModel 클래스를 상속한 다음 해당 메서드를 사용하여 추가, 삭제, 수정 및 검색과 같은 작업을 수행하면 됩니다.

위 내용은 ThinkPHP6에서 AR을 사용하여 데이터베이스를 운영하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
ThinkPhp의 내장 테스트 프레임 워크의 주요 기능은 무엇입니까?ThinkPhp의 내장 테스트 프레임 워크의 주요 기능은 무엇입니까?Mar 18, 2025 pm 05:01 PM

이 기사는 ThinkPhp의 내장 테스트 프레임 워크에 대해 논의하여 장치 및 통합 테스트와 같은 주요 기능과 조기 버그 감지 및 개선 된 코드 품질을 통해 응용 프로그램 신뢰성을 향상시키는 방법을 강조합니다.

실시간 주식 시장 데이터 피드 구축에 ThinkPhp를 사용하는 방법은 무엇입니까?실시간 주식 시장 데이터 피드 구축에 ThinkPhp를 사용하는 방법은 무엇입니까?Mar 18, 2025 pm 04:57 PM

기사는 실시간 주식 시장 데이터 피드에 ThinkPHP를 사용하여 설정, 데이터 정확도, 최적화 및 보안 측정에 중점을 둡니다.

서버리스 아키텍처에서 ThinkPhp를 사용하는 데있어 주요 고려 사항은 무엇입니까?서버리스 아키텍처에서 ThinkPhp를 사용하는 데있어 주요 고려 사항은 무엇입니까?Mar 18, 2025 pm 04:54 PM

이 기사는 서버리스 아키텍처에서 ThinkPHP를 사용하기위한 주요 고려 사항에 대해 설명하고 성능 최적화, 무국적 설계 및 보안에 중점을 둡니다. 비용 효율성 및 확장 성과 같은 혜택을 강조하고 도전 과제를 해결합니다.

ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱을 구현하는 방법은 무엇입니까?ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱을 구현하는 방법은 무엇입니까?Mar 18, 2025 pm 04:51 PM

이 기사에서는 ThinkPHP 마이크로 서비스에서 서비스 검색 및로드 밸런싱 구현, 설정, 모범 사례, 통합 방법 및 권장 도구에 중점을 둡니다. [159 문자]

ThinkPhp의 종속성 주입 컨테이너의 고급 기능은 무엇입니까?ThinkPhp의 종속성 주입 컨테이너의 고급 기능은 무엇입니까?Mar 18, 2025 pm 04:50 PM

ThinkPhp의 IOC 컨테이너는 PHP apps.character 수 : 159의 효율적인 종속성 관리를위한 게으른 하중, 맥락 바인딩 및 메소드 주입과 같은 고급 기능을 제공합니다.

실시간 협업 도구를 구축하는 데 ThinkPhp를 사용하는 방법은 무엇입니까?실시간 협업 도구를 구축하는 데 ThinkPhp를 사용하는 방법은 무엇입니까?Mar 18, 2025 pm 04:49 PM

이 기사는 ThinkPhp를 사용하여 실시간 협업 도구를 구축하고 설정, WebSocket 통합 및 보안 모범 사례에 중점을 둡니다.

SaaS 애플리케이션 구축에 ThinkPhp를 사용하면 어떤 주요 이점이 있습니까?SaaS 애플리케이션 구축에 ThinkPhp를 사용하면 어떤 주요 이점이 있습니까?Mar 18, 2025 pm 04:46 PM

ThinkPhp는 가벼운 디자인, MVC 아키텍처 및 확장 성을 통해 SaaS 앱에 혜택을줍니다. 다양한 기능을 통해 확장 성을 향상시키고 개발 속도를 높이며 보안을 향상시킵니다.

ThinkPHP 및 RabbitMQ로 분산 작업 대기열 시스템을 구축하는 방법은 무엇입니까?ThinkPHP 및 RabbitMQ로 분산 작업 대기열 시스템을 구축하는 방법은 무엇입니까?Mar 18, 2025 pm 04:45 PM

이 기사는 설치, 구성, 작업 관리 및 확장성에 중점을 둔 ThinkPhp 및 RabbitMQ를 사용하여 분산 작업 큐 시스템을 구축합니다. 주요 문제는 고 가용성 보장, 손상과 같은 일반적인 함정을 피하는 것입니다.

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를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

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

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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