> PHP 프레임워크 > YII > YII (일대일, 다수)의 관계형 데이터베이스를 어떻게 사용합니까?

YII (일대일, 다수)의 관계형 데이터베이스를 어떻게 사용합니까?

James Robert Taylor
풀어 주다: 2025-03-11 15:47:43
원래의
167명이 탐색했습니다.

YII (일대일, 다수)의 관계형 데이터베이스 작업

yii는 특히 일대일적이고 다수의 관계를 다룰 때 관계형 데이터베이스와의 작업을 단순화하는 GII라는 강력한 개체 관계 매퍼 (ORM)를 제공합니다. 이러한 관계는 ActiveRecord를 사용하여 모델 클래스 내에서 정의됩니다.

일대일 관계 : 이것은 테이블의 한 레코드가 다른 테이블의 여러 레코드와 연관 될 수있는 시나리오를 나타냅니다. 예를 들어, 저자 모델에는 많은 book 모델이있을 수 있습니다. hasmany () 메소드를 사용하여 저자 모델에서 이것을 정의합니다. yii를 사용하십시오. yii \ db \ activerecord를 사용하십시오; Class author는 activerecord {public static function tabename () {return 'audrors'; } public function getBooks () {return $ this- & gt; hasmany (book :: classname (), [ 'author_id'= & gt; 'id']); }}

이 예에서는 getBooks () 관계를 정의합니다. book :: classname () 관련 모델을 지정하고 [ 'author_id'= & gt; 'id'] author_id books 테이블의 외국 키를 id 저자 테이블의 기본 키에 맵핑합니다. 이제 다음과 같은 저자의 책에 액세스 할 수 있습니다 : $ author- & gt; books . 예를 들어, 학생 모델은 많은 코스 모델에 등록 될 수 있으며 코스 모델에는 학생 모델이 많을 수 있습니다. 이를 위해서는 두 테이블을 연결하기 위해 정션 테이블 (예 : wident_course )이 필요합니다.

 <code class="php"> & lt;? php namespace app \ models; yii를 사용하십시오. yii \ db \ activerecord를 사용하십시오; 클래스 학생 확장 activeRecord {public static function tabename () {return 'withying'; } public function getCourses () {return $ this- & gt; hasmany (course :: classname (), [ 'id'= & gt; 'course_id]]) -& gt; }} & lt;? php 네임 스페이스 앱 \ 모델; yii를 사용하십시오. yii \ db \ activerecord를 사용하십시오; 클래스 코스 확장 activereCord {public static function tabename () {return 'courses'; } public function getStudents () {return $ $ this- & gt; hasmany (whity :: classname (), [ 'id'= & gt; 'wichain_id]) -& gt; }} </code> 
로그인 후 복사

여기, viatable () 정션 테이블과 외국 키 매핑을 지정합니다. $ 학생-& gt; 과정 및 코스 학생들을 사용하여 학생의 코스에 액세스 할 수 있으며 $ course- & gt; 학생 . 데이터베이스 상호 작용을 추상화하십시오. 이것은 코드 가독성과 유지 가능성을 향상시킵니다.

  • 관계를 명확하게 정의합니다. 설명 관계 이름 (예 : getbooks () , getcourses () ) 사용 정확한 외국 키 매핑 :
  • egger로드 사용을 보장합니다. ( with () method) 단일 쿼리에서 관련 데이터를 가져 오기 위해. 예를 들어 $ author = author :: findone (1)-& gt; with ( 'books')-& gt; one (); 이것은 한 데이터베이스 쿼리에서 저자와 그들의 책을 검색합니다.
  • 관계 유효성 검증 : 데이터 무결성을 보장합니다. 예를 들어, 책이 저자에 속하는지 또는 학생이 코스에 등록되어 있는지 확인합니다.
  • 트랜잭션 사용 : 트랜잭션 내에서 데이터베이스 작업을 랩핑하여 데이터 일관성을 유지하기 위해 특히 여러 테이블과 관련된 작업에 대해 데이터 일관성을 유지합니다. YII의 ActiveRecord 기능 및 데이터베이스 최적화 기술을 활용합니다.
    • eger loading (()) : 앞에서 언급 한 바와 같이 () 는 n 1 쿼리를 피하는 데 중요합니다. 이는 관련 데이터를 검색 할 때 성능을 크게 향상시킵니다.
    • 조건 및 필터링 : 관련 데이터를 필터링하기위한 여기서 () 및 기타 쿼리 빌드 방법을 사용합니다. 예를 들어, 특정 날짜 이후에 출판 된 저자의 책을 얻으려면 $ author- & gt; books ()-& gt; where ([ '& gt;', '2023-01-01'])-& gt;
    • 에 가입 한 joh on joh on joh on joh john john 최적의 성능을위한 쿼리. YII는 쿼리 빌더를 사용하여 복잡한 쿼리를 구축 할 수 있습니다.
    • 인덱싱 : 외래 키에 대한 적절한 데이터베이스 인덱싱을 조회 속도를 높이기 위해 적절한 데이터베이스 인덱싱을 보장합니다.
    • Pagtination : 큰 데이터 세트의 경우 한 번에과 관련된 데이터를 검색하고 처리하지 않기 위해 Pagitination을 사용하여 데이터를 검색하고 처리하지 않습니다. 관계 데이터에 대한 관계형 데이터베이스 모델

      관련 데이터에 대한 작업 (생성, 읽기, 업데이트, 삭제) 작업은 데이터 일관성을 유지하기 위해 신중한 처리가 필요합니다.

      • 작성 : 새로운 관련 레코드를 작성할 때 외국 키 관계가 올바르게 설정되어 있는지 확인하십시오. 예를 들어, 새 책을 만들 때 author_id . 트랜잭션을 사용하여 데이터 일관성을 확인하십시오.
      • 삭제 : 레코드 삭제하려면 계단식 삭제 또는 관련 레코드를 적절하게 처리해야 할 수 있습니다. 예를 들어, 저자를 삭제하려면 데이터베이스 제약 조건 및 응용 프로그램 논리에 따라 관련 책을 삭제해야 할 수 있습니다. YII의 ActiveRecord는 삭제 작업 중에 이러한 관계를 관리하는 기능을 제공합니다. 데이터 불일치를 방지하기 위해 deleteall () 를 사용하거나 트랜잭션 내 삭제 프로세스를 신중하게 처리하는 것을 고려하십시오.

      특정 테이블과 모델 이름에 맞게이 예제를 조정하십시오. 데이터 무결성과 성능을 보장하기 위해 항상 코드를 철저히 테스트하십시오.

  • 위 내용은 YII (일대일, 다수)의 관계형 데이터베이스를 어떻게 사용합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
    저자별 최신 기사
    인기 튜토리얼
    더>
    최신 다운로드
    더>
    웹 효과
    웹사이트 소스 코드
    웹사이트 자료
    프론트엔드 템플릿