백엔드 개발 PHP 튜토리얼 CakePHP에서 데이터를 쿼리하고 업데이트하는 방법은 무엇입니까?

CakePHP에서 데이터를 쿼리하고 업데이트하는 방법은 무엇입니까?

Jun 03, 2023 pm 02:11 PM
고쳐 쓰다 cakephp 데이터 쿼리

CakePHP는 편리한 ORM(객체 관계형 매핑) 기능을 제공하여 데이터베이스 쿼리 및 업데이트를 매우 쉽게 해주는 인기 있는 PHP 프레임워크입니다.

이 글에서는 CakePHP에서 데이터를 쿼리하고 업데이트하는 방법을 소개합니다. 간단한 쿼리 및 업데이트부터 시작하여 조건 및 관련 모델을 사용하여 데이터를 더 복잡하게 쿼리하고 업데이트하는 방법을 살펴보겠습니다.

  1. 기본 쿼리

먼저 가장 간단한 쿼리를 만드는 방법을 살펴보겠습니다. "Users"라는 데이터 테이블이 있고 모든 사용자 레코드를 검색한다고 가정합니다.

CakePHP에서는 find 메소드를 사용하여 데이터를 검색할 수 있습니다. 다음은 샘플 코드입니다.

$users = $this->Users->find('all');
로그인 후 복사

이렇게 하면 모든 사용자 기록이 포함된 배열이 반환됩니다. 하나의 레코드만 검색하려는 경우 find('first') 메소드를 사용할 수 있습니다.

$user = $this->Users->find('first');
로그인 후 복사

이렇게 하면 첫 번째 사용자 레코드가 반환됩니다. 또한 find('list') 메소드를 사용하여 키-값 쌍의 해시 테이블을 검색할 수 있습니다. 여기서 키는 레코드의 기본 키이고 값은 지정된 필드입니다. 예를 들어 사용자 ID와 이름의 해시 테이블을 얻으려면 다음 코드를 사용할 수 있습니다.

$users = $this->Users->find('list', ['keyField' => 'id', 'valueField' => 'name']);
로그인 후 복사
  1. 조건부 쿼리

조건부 쿼리를 수행해야 할 때 CakePHP는 데이터를 필터링하는 편리한 방법을 제공합니다. 쿼리 결과. where 및 andWhere 메소드를 사용하여 프로그래밍 방식으로 쿼리 조건을 작성할 수 있습니다. 다음은 샘플 코드입니다.

$users = $this->Users->find()
    ->where(['age >' => 18, 'name LIKE' => '%John%'])
    ->andWhere(['gender' => 'male'])
    ->all();
로그인 후 복사

위 코드에서는 where 및 andWhere 메소드를 사용하여 쿼리 조건을 지정했습니다. 첫 번째 조건은 18세 이상이고 이름에 "John"이 포함된 사용자를 지정합니다. 두 번째 조건은 성별이 "남성"인 사용자를 지정합니다. 마지막으로, 기준을 충족하는 모든 사용자 레코드를 검색하기 위해 all 메소드를 사용합니다.

IN, NOT IN, BETWEEN 등과 같은 복잡한 쿼리 조건을 사용할 수도 있습니다. 다음은 샘플 코드입니다.

$users = $this->Users->find()
    ->where(['age BETWEEN' => [18, 25]])
    ->andWhere(['state IN' => ['CA', 'NY', 'TX']])
    ->all();
로그인 후 복사

위 코드에서는 BETWEEN 및 IN 조건을 사용하여 18세에서 25세 사이이고 상태가 CA, NY 또는 TX인 사용자를 지정했습니다. 이번에도 all 메소드를 사용하여 기준을 충족하는 모든 사용자 레코드를 검색합니다.

  1. 관련 쿼리

CakePHP에서는 관련 쿼리를 쉽게 수행할 수 있습니다. 사용자 레코드 외에 "게시물"이라는 데이터 테이블이 있고 각 사용자가 여러 개의 게시물을 가지고 있다고 가정해 보겠습니다. 사용자와 해당 사용자의 모든 게시물을 쿼리하는 방법을 살펴보겠습니다.

먼저 User 모델에서 Posts 연관을 정의해야 합니다. 소속된 메소드를 사용하여 데이터 테이블을 사용자 모델에 연결할 수 있습니다. 다음은 샘플 코드입니다.

class UsersTable extends Table
{
    public function initialize(array $config)
    {
        $this->hasMany('Posts');
    }
}
로그인 후 복사

위 코드에서는 hasMany 메서드를 사용하여 User 모델과 Posts 데이터 테이블 간의 연결을 지정합니다.

이제 관련 쿼리의 find 메소드를 사용하여 모든 사용자와 해당 기사를 모두 가져올 수 있습니다. 다음은 샘플 코드입니다.

$users = $this->Users->find('all', [
    'contain' => ['Posts']
]);
로그인 후 복사

위 코드에서는 연결할 데이터 테이블을 지정하기 위해 contain 옵션을 사용했습니다. 배열을 통해 여러 연결을 지정할 수도 있습니다. 예를 들어, User 모델이 Comments 테이블과 연관되어 있는 경우 다음과 같이 작성할 수 있습니다:

$users = $this->Users->find('all', [
    'contain' => ['Posts', 'Comments']
]);
로그인 후 복사

연관 쿼리를 수행할 때 CakePHP는 내부 조인(INNER JOIN)을 사용하여 두 데이터 테이블을 결합하여 연관된 데이터를 얻습니다. LEFT JOIN 또는 RIGHT JOIN을 사용하려면 연관 정의에서 이를 지정할 수 있습니다.

  1. Data Update

데이터베이스의 레코드를 업데이트해야 할 때 CakePHP는 업데이트 작업을 수행하는 편리한 방법을 제공합니다. updateAll 메서드를 사용하여 프로그래밍 방식으로 레코드를 업데이트할 수 있습니다. 다음은 샘플 코드입니다.

$result = $this->Users->updateAll(
    ['age' => 25],
    ['name LIKE' => '%John%']
);
로그인 후 복사

위 코드에서는 updateAll 메서드를 사용하여 이름에 "John"이 포함된 25세의 모든 사용자를 업데이트합니다. updateAll 메소드는 두 개의 매개변수를 허용합니다. 첫 번째 매개변수는 설정할 열과 값을 지정합니다. 위의 예에서는 나이를 25세로 설정했습니다. 두 번째 매개변수는 업데이트할 레코드의 기준을 지정합니다.

하나의 레코드만 업데이트하려면 저장 방법을 사용하면 됩니다. 다음은 샘플 코드입니다.

$user = $this->Users->get(1);
$user->age = 25;
$this->Users->save($user);
로그인 후 복사

위 코드에서는 get 메소드를 사용하여 ID 1의 사용자 레코드를 검색했습니다. 그런 다음 레코드의 수명을 업데이트하고 save 메소드를 사용하여 변경 사항을 저장합니다.

기록을 삭제해야 할 경우 CakePHP에서 제공하는 deleteAll 및 delete 메소드를 사용할 수도 있습니다.

요약

이번 글에서는 CakePHP에서 데이터 쿼리 및 업데이트를 수행하는 방법을 소개했습니다. 간단한 쿼리 및 업데이트 방법을 사용하는 방법과 더 복잡한 쿼리 및 업데이트에 조건부 및 관계형 모델을 사용하는 방법을 배웠습니다. CakePHP에서 제공하는 편리한 ORM 기능을 사용하면 애플리케이션 요구 사항에 맞게 데이터베이스를 쉽게 조작할 수 있습니다.

위 내용은 CakePHP에서 데이터를 쿼리하고 업데이트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Blizzard Battle.net 업데이트가 45%에서 멈추는 문제를 해결하는 방법은 무엇입니까? Blizzard Battle.net 업데이트가 45%에서 멈추는 문제를 해결하는 방법은 무엇입니까? Mar 16, 2024 pm 06:52 PM

블리자드 Battle.net 업데이트가 45%에서 계속 멈춥니다. 어떻게 해결하나요? 최근 많은 사람들이 소프트웨어를 업데이트할 때 진행률이 45%에서 멈췄습니다. 여러 번 다시 시작해도 계속 멈춥니다. 그렇다면 이 상황을 해결하려면 어떻게 해야 할까요? 이 소프트웨어 튜토리얼은 더 많은 사람들에게 도움이 되기를 바라며 작업 단계를 공유할 것입니다. 블리자드 Battle.net 업데이트가 45%에서 계속 멈춥니다. 해결 방법 1. 클라이언트 1. 먼저 클라이언트가 공식 웹사이트에서 다운로드한 공식 버전인지 확인해야 합니다. 2. 그렇지 않은 경우 사용자는 아시아 서버 웹사이트에 들어가 다운로드할 수 있습니다. 3. 입력 후 오른쪽 상단의 다운로드를 클릭하세요. 참고: 설치할 때 중국어 간체를 선택하지 마십시오.

CakePHP 프로젝트 구성 CakePHP 프로젝트 구성 Sep 10, 2024 pm 05:25 PM

이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

CakePHP 데이터베이스 작업 CakePHP 데이터베이스 작업 Sep 10, 2024 pm 05:25 PM

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

에픽세븐 2월 22일 업데이트: 미라클 메이드 왕국 2주차가 시작됩니다. 에픽세븐 2월 22일 업데이트: 미라클 메이드 왕국 2주차가 시작됩니다. Feb 21, 2024 pm 05:52 PM

에픽세븐은 2월 22일 낮 11시 지속적인 업데이트가 확정되었습니다. 이번 업데이트를 통해 레아의 한정 소환률 증가, 달콤한 미라클, 신비한 카드 풀 업데이트 등 다양한 신규 활동과 콘텐츠가 선보일 예정입니다. , 스페셜 서브 스토리 미라클 메이드 왕국의 두 번째 주가 시작되었습니다. 모바일 게임 업데이트 일정 : The Seventh Epic 2월 22일 업데이트 예정 : 미라클 메이드 왕국 2주차 오픈 ※'레이아' & '스위트 미라클' 한정 소환 확률 UP! ■기간 한정 소환 확률 업 시간 : -2024/02/22(목) 11:00 ~ 2024/03/07(목) 10:59 ■캐릭터 속성 및 직업 : 타고난 속성, 전사 ■캐릭터 소개 : 4인 밴드 더 기적의 메이드 왕국'의 서브보컬이자 베이(Bei)

Ubuntu 24.04에 Angular를 설치하는 방법 Ubuntu 24.04에 Angular를 설치하는 방법 Mar 23, 2024 pm 12:20 PM

Angular.js는 동적 애플리케이션을 만들기 위해 자유롭게 액세스할 수 있는 JavaScript 플랫폼입니다. HTML 구문을 템플릿 언어로 확장하여 애플리케이션의 다양한 측면을 빠르고 명확하게 표현할 수 있습니다. Angular.js는 코드를 작성, 업데이트 및 테스트하는 데 도움이 되는 다양한 도구를 제공합니다. 또한 라우팅 및 양식 관리와 같은 많은 기능을 제공합니다. 이 가이드에서는 Ubuntu24에 Angular를 설치하는 방법에 대해 설명합니다. 먼저 Node.js를 설치해야 합니다. Node.js는 서버 측에서 JavaScript 코드를 실행할 수 있게 해주는 ChromeV8 엔진 기반의 JavaScript 실행 환경입니다. Ub에 있으려면

랜턴과 던전 2월 29일 업데이트 : 리마스터 버전 ╳ '네자 전설' 연계 랜턴과 던전 2월 29일 업데이트 : 리마스터 버전 ╳ '네자 전설' 연계 Feb 28, 2024 am 08:13 AM

랜턴앤던전스는 2월 29일 업데이트가 확정되었으며, 업데이트 이후 랜턴앤던전스의 리마스터 버전이 출시될 예정이며, 리마스터 버전 역시 레전드 오브 나타와 연동될 예정이다. 직업 변경, 플레이어 직접 직업 변경, 던전 콘텐츠 확장, 새로운 던전 지역 오픈 등이 가능합니다. 모바일게임 업데이트 일정 랜턴과 던전 2월 29일 업데이트 : 리마스터 버전 ╳ '네자전설' ​​연계버전 주요 내용 신규 직업, 전직을 권유받은 이유는 무엇입니까? . 전직 후 랜턴 홀더도 멋진 기술을 많이 배울 수 있다고 들었습니다. 고로는 태국 바지가 뜨겁습니다! 나타의 전설이 함께 온다! 뜨거운 바퀴를 밟고 천지의 원을 손에 쥐고 ♫ ~ 현명하고 용감한 작은 영웅 나타와 어린 용 소녀가 곧 온다

Windows가 지정된 장치, 경로 또는 파일에 액세스할 수 없습니다. Windows가 지정된 장치, 경로 또는 파일에 액세스할 수 없습니다. Jun 18, 2024 pm 04:49 PM

친구의 컴퓨터에 이러한 오류가 있습니다. "이 PC"와 C 드라이브 파일을 열면 "Explorer.EXE Windows가 지정된 장치, 경로 또는 파일에 액세스할 수 없습니다. 프로젝트에 액세스할 수 있는 적절한 권한이 없을 수 있습니다. " 폴더, 파일, 이 컴퓨터, 휴지통 등을 포함하여 더블클릭하면 이런 창이 뜨는데, 마우스 오른쪽 버튼을 클릭해서 여는 것이 정상입니다. 이는 시스템 업데이트로 인해 발생합니다. 이러한 상황이 발생하면 아래 편집기에서 해결 방법을 알려드립니다. 1. 레지스트리 편집기 Win+R을 열고 regedit를 입력하거나 시작 메뉴를 마우스 오른쪽 버튼으로 클릭하여 실행하고 regedit를 입력합니다. 2. "Computer\HKEY_CLASSES_ROOT\PackagedCom\ClassInd" 레지스트리를 찾습니다.

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

See all articles