심포니-교리 ORM

Symfony 웹 프레임 워크에서 모델은 중요한 역할을합니다. 그들은 사업체입니다. 고객이 제공하거나 백엔드 데이터베이스에서 가져 와서 비즈니스 규칙에 따라 조작하고 데이터베이스에 다시 유지합니다. 뷰에서 제공하는 데이터입니다. 이 장에서 모델과 모델이 백엔드 시스템과 상호 작용하는 방법에 대해 알아 보겠습니다.

데이터베이스 모델

모델을 안전하고 효율적으로 가져오고 유지하려면 모델을 백엔드 관계형 데이터베이스 항목에 매핑해야합니다. 이 매핑은 ORM (Object Relational Mapping) 도구를 사용하여 수행 할 수 있습니다. Symfony는 별도의 번들을 제공합니다.DoctrineBundle, Symfony를 타사 PHP 데이터베이스 ORM 도구와 통합합니다. Doctrine.

교리 ORM

기본적으로 Symfony 프레임 워크는 데이터베이스 작업을위한 구성 요소를 제공하지 않습니다. 그러나 그것은Doctrine ORM. Doctrine에는 데이터베이스 저장 및 개체 매핑에 사용되는 여러 PHP 라이브러리가 포함되어 있습니다.

다음 예제는 Doctrine의 작동 방식, 데이터베이스 구성 방법 및 데이터 저장 및 검색 방법을 이해하는 데 도움이됩니다.

교리 ORM 예

이 예에서는 먼저 데이터베이스를 구성하고 Student 개체를 만든 다음 여기에서 몇 가지 작업을 수행합니다.

이를 위해 다음 단계를 준수해야합니다.

1 단계 : Symfony 애플리케이션 생성

Symfony 애플리케이션을 만듭니다. dbsample 다음 명령을 사용하십시오.

symfony new dbsample

2 단계 : 데이터베이스 구성

일반적으로 데이터베이스 정보는“app / config / parameters.yml”파일에 구성됩니다.

파일을 열고 다음 변경 사항을 추가하십시오.

parameter.yml

parameters: 
   database_host: 127.0.0.1 
   database_port: null
   database_name: studentsdb 
   database_user: <user_name> 
   database_password: <password> 
   mailer_transport: smtp 
   mailer_host: 127.0.0.1 
   mailer_user: null 
   mailer_password: null 
   secret: 037ab82c601c10402408b2b190d5530d602b5809 
   
   doctrine: 
      dbal: 
      driver:   pdo_mysql 
      host:     '%database_host%' 
      dbname:   '%database_name%' 
      user:     '%database_user%' 
      password: '%database_password%' 
      charset: utf8mb4

이제 Doctrine ORM이 데이터베이스에 연결할 수 있습니다.

3 단계 : 데이터베이스 생성

다음 명령을 실행하여“studentsdb”데이터베이스를 생성합니다. 이 단계는 Doctrine ORM에서 데이터베이스를 바인딩하는 데 사용됩니다.

php bin/console doctrine:database:create

명령을 실행하면 빈 "studentsdb"데이터베이스가 자동으로 생성됩니다. 화면에서 다음과 같은 응답을 볼 수 있습니다.

Created database `studentsdb` for connection named default

4 단계 :지도 정보

매핑 정보는 "메타 데이터"에 지나지 않으며 Student 클래스와 해당 속성이 특정 데이터베이스 테이블에 매핑되는 방식을 정확히 Doctrine ORM에 알려주는 규칙 모음입니다.

이 메타 데이터는 YAML, XML을 포함한 다양한 형식으로 지정하거나 주석을 사용하여 Student 클래스를 직접 전달할 수 있습니다. 다음과 같이 정의됩니다.

Student.php

파일에 다음 변경 사항을 추가하십시오.

<?php  
namespace AppBundle\Entity;  

use Doctrine\ORM\Mapping as ORM;  
/** 
   * @ORM\Entity 
   * @ORM\Table(name = "students") 
*/ 
class Student { 
   /** 
      * @ORM\Column(type = "integer") 
      * @ORM\Id 
      * @ORM\GeneratedValue(strategy = "AUTO") 
   */ 
   private $id; /** * @ORM\Column(type = "string", length = 50) */ private $name;  
   
   /** 
     * @ORM\Column(type = "text") 
     */ 
   private $address; 
}

여기서 테이블 이름은 선택 사항입니다. 테이블 이름을 지정하지 않으면 엔티티 클래스의 이름에 따라 자동으로 결정됩니다.

5 단계 : 항목 바인딩

Doctrine은 간단한 엔티티 클래스를 생성합니다. 모든 엔티티를 구축하는 데 도움이됩니다.

다음 명령을 실행하여 엔티티를 생성하십시오.

php bin/console doctrine:generate:entities AppBundle/Entity/Student

그러면 다음 결과가 표시되고 엔티티가 업데이트됩니다.

Generating entity "AppBundle\Entity\Student" 
   > backing up Student.php to Student.php~ 
   > generating AppBundle\Entity\Student

Student.php

<?php 
namespace AppBundle\Entity; 

use Doctrine\ORM\Mapping as ORM;  
/** 
   * @ORM\Entity 
   * @ORM\Table(name="students") 
*/ 
class Student { 
   /** 
      * @ORM\Column(type="integer") 
      * @ORM\Id 
      * @ORM\GeneratedValue(strategy="AUTO") 
   */ 
   private $id;  
    
   /** 
      * @ORM\Column(type = "string", length = 50) 
   */ 
   private $name; /** * @ORM\Column(type = "text") */ private $address; 
    
   /** 
      * Get id 
      * 
      * @return integer 
   */ 
   public function getId() { 
      return $this->id; } /** * Set name * * @param string $name 
      * 
      * @return Student 
   */ 
    
   public function setName($name) { $this->name = $name; return $this; 
   }  
    
   /** 
      * Get name 
      * 
      * @return string 
   */ 
    
   public function getName() { 
      return $this->name; } /** * Set address * * @param string $address 
      * 
      * @return Student 
   */ 
    
   public function setAddress($address) { $this->address = $address; return $this; 
   }  
    
   /** 
      * Get address 
      * 
      * @return string 
   */ 
   
   public function getAddress() { 
      return $this->address; 
   } 
}

6 단계 :지도 유효성 검사

엔터티를 만든 후 다음 명령을 사용하여 매핑의 유효성을 검사해야합니다.

php bin/console doctrine:schema:validate

다음 결과가 생성됩니다-

[Mapping]  OK - The mapping files are correct. 
[Database] FAIL - The database schema is not in sync with the current mapping file

student 테이블을 생성하지 않았으므로 엔티티가 동기화되지 않습니다. 다음 단계에서 Symfony 명령을 사용하여 students 테이블을 생성하겠습니다.

7 단계 : 스키마 생성

Doctrine은 Student 엔티티에 필요한 모든 데이터베이스 테이블을 자동으로 생성 할 수 있습니다. 다음 명령을 사용하여 수행 할 수 있습니다.

php bin/console doctrine:schema:update --force

명령을 실행하면 다음과 같은 응답을 볼 수 있습니다.

Updating database schema... 
Database schema updated successfully! "1" query was executed

이 명령은 데이터베이스의 모양과 실제 모양을 비교하고 데이터베이스 스키마를 있어야하는 위치로 업데이트하는 데 필요한 SQL 문을 실행합니다.

이제 다음 명령을 사용하여 스키마를 다시 확인합니다.

php bin/console doctrine:schema:validate

다음 결과가 생성됩니다-

[Mapping]  OK - The mapping files are correct. 
[Database] OK - The database schema is in sync with the mapping files

8 단계 : 게터 및 세터

Bind an Entity 섹션에서 볼 수 있듯이 다음 명령은 Student 클래스에 대한 모든 getter 및 setter를 생성합니다.

$ php bin/console doctrine:generate:entities AppBundle/Entity/Student

9 단계 : 데이터베이스에 개체 유지

이제 Student 엔터티를 해당 Student 테이블에 매핑했습니다. 이제 Student 개체를 데이터베이스에 유지할 수 있어야합니다. 번들의 StudentController에 다음 메서드를 추가합니다.

StudentController.php

<?php  
namespace AppBundle\Controller; 

use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route; 
use Symfony\Bundle\FrameworkBundle\Controller\Controller; 
use Symfony\Component\HttpFoundation\Response;  
use AppBundle\Entity\Student; 

class StudentController extends Controller { 
   /** 
      * @Route("/student/add") 
   */ 
   public function addAction() { 
      $stud = new Student(); $stud->setName('Adam'); 
      $stud->setAddress('12 north street'); $doct = $this->getDoctrine()->getManager(); // tells Doctrine you want to save the Product $doct->persist($stud); //executes the queries (i.e. the INSERT query) $doct->flush(); 
      
      return new Response('Saved new student with id ' . $stud->getId()); 
   } 
}

여기서는 기본 컨트롤러의 getDoctrine ()을 통해 getManager () 메서드를 사용하여 doctrine manager에 액세스 한 다음 doctrine manager의 persist () 메서드를 사용하여 현재 객체를 유지합니다. persist() 메서드는 큐에 명령을 추가하지만 flush() 메서드는 실제 작업을 수행합니다 (학생 개체 유지).

10 단계 : 데이터베이스에서 개체 가져 오기

StudentController에 학생 세부 정보를 표시하는 함수를 만듭니다.

StudentController.php

/** 
   * @Route("/student/display") 
*/ 
public function displayAction() { 
   $stud = $this->getDoctrine() ->getRepository('AppBundle:Student') ->findAll(); return $this->render('student/display.html.twig', array('data' => $stud)); 
}

11 단계 :보기 만들기

표시 동작을 가리키는 뷰를 만들어 보겠습니다. 보기 디렉토리로 이동하여 "display.html.twig"파일을 만듭니다. 파일에 다음 변경 사항을 추가하십시오.

display.html.twig

<style> 
   .table { border-collapse: collapse; } 
   .table th, td { 
      border-bottom: 1px solid #ddd; 
      width: 250px; 
      text-align: left; 
      align: left; 
   } 
</style> 

<h2>Students database application!</h2>  
<table class = "table">  
   <tr>  
      <th>Name</th>  
      <th>Address</th>  
   </tr>  
   {% for x in data %} 
   <tr>  
      <td>{{ x.Name }}</td>   
      <td>{{ x.Address }}</td>   
   </tr>  
   {% endfor %} 
</table>

브라우저에서 URL“http : // localhost : 8000 / student / display”를 요청하여 결과를 얻을 수 있습니다.

화면에 다음과 같은 출력이 생성됩니다.

12 단계 : 개체 업데이트

StudentController에서 개체를 업데이트하려면 작업을 만들고 다음 변경 사항을 추가합니다.

/** 
   * @Route("/student/update/{id}") 
*/ 
public function updateAction($id) { 
   $doct = $this->getDoctrine()->getManager(); 
   $stud = $doct->getRepository('AppBundle:Student')->find($id); if (!$stud) { 
      throw $this->createNotFoundException( 'No student found for id '.$id 
      ); 
   } 
   $stud->setAddress('7 south street'); $doct->flush(); 
   
   return new Response('Changes updated!'); 
}

이제 URL“http : // localhost : 8000 / Student / update / 1”을 요청하면 다음과 같은 결과가 생성됩니다.

화면에 다음과 같은 출력이 생성됩니다.

13 단계 : 개체 삭제

객체를 삭제하는 것도 비슷하며 엔티티 (독트린) 관리자의 remove () 메소드를 호출해야합니다.

다음 명령을 사용하여 수행 할 수 있습니다.

/** 
   * @Route("/student/delete/{id}") 
*/ 
public function deleteAction($id) { $doct = $this->getDoctrine()->getManager(); $stud = $doct->getRepository('AppBundle:Student')->find($id);  
    
   if (!$stud) { throw $this->createNotFoundException('No student found for id '.$id); } $doct->remove($stud); $doct->flush();  
   
   return new Response('Record deleted!'); 
}