다음 방법을 사용하여
{지정된 사용자의 노트에 키워드 키워드가 포함된 모든 정보를 쿼리}
SQL 문
SELECT * FROM Users AS User LEFT JOIN Notes AS Note ON User.id = Note.user_id WHERE User.id = {$user_id} AND Note.subject LIKE '%{keyword}%'을 달성할 수 있습니다.
그런 다음 이 SQL 문을 실행하고 모델의 쿼리 메서드를 사용합니다.
$data = $this->User->query($sql);
2. 모델의 bindModel() 및 unbindModel() 메서드를 사용합니다.
이 두 메서드에 대한 지침은 다음을 참조하세요.
http://api.cakephp.org/class/model
을 참조하세요. 우리의 접근 방식은
//重新绑定关联指定查询条件 $this->User->unbindModel('Note'); $this->User->bindModel( 'hasMany' => array( 'Note' => array( 'conditions' => array( 'Note.subject LIKE' => '%'.$keyword.'%' ) ) ) ); //指定主表条件获取数据 $data = $this->User->find('all',array( 'conditions' => array( 'User.id' => $user_id ) )); //或者 $data = $this->User->read(null,$user_id);
3입니다. . Cakephp의 핵심 동작(Behavior) Containable
을 사용하여 먼저 자체 AppModel 클래스를 만들고 /app/app_model.php
class AppModel extends Model { //加载核心行为 var $actsAs = array('Containable'); }
파일을 만든 다음 컨트롤러에 전달할 수 있습니다. 코드 쿼리
$this->User->contain('Note.subject LIKE' => '%'.$keyword.'%'); $data = $this->User->find('all',array( 'conditions' => array( 'User.id' => $user_id ) ));
는 다음
$data = $this->User->find('all',array( 'conditions' => array( 'User.id' => $user_id ), 'contain' => array( 'Note' => array( 'conditions' => array( 'Note.subject LIKE' => '%'.$keyword.'%' ) ) ) ));
과 유사하게 find 문에 직접 작성할 수도 있습니다. 참고:
쿼리하려는 경우 {User.name 또는 Note.subject에는 키워드 키워드의 모든 레코드가 포함됩니다.}
이때 Cakephp의 find 메소드는 이 쿼리를 구현할 수 없으며, 위에서 소개한 사용자 정의 SQL 문을 다음과 같이 사용해야 합니다.
SELECT * FROM users AS User LEFT JOIN notes AS Note ON User.id = Note.user_id WHERE User.name LIKE '%keyword%' OR Note.subject LIKE '%keyword%'
위 내용은 Cakephp에서 연관 테이블을 조회하는 방법을 요약한 것입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

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

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전
