>  기사  >  PHP 프레임워크  >  yii 프레임워크를 데이터베이스에 연결하는 방법

yii 프레임워크를 데이터베이스에 연결하는 방법

(*-*)浩
(*-*)浩원래의
2019-11-27 13:57:433181검색

yii 프레임워크를 데이터베이스에 연결하는 방법

yii 프레임워크 구성 데이터베이스 연결

시작하기 전에 PHP PDO 확장과 사용 중인 데이터베이스(예: MySQL의 pdo_mysql)의 PDO 드라이버 를 설치했는지 확인하세요. 관계형 데이터베이스를 사용하기 위한 이것은 기본 요구 사항입니다. > (권장 학습: yii 프레임워크 )

드라이버와 확장 프로그램을 설치하고 사용할 수 있게 되면 config/db.php를 열고 내부의 구성 매개변수를 데이터베이스 구성에 맞게 수정하세요. 파일에는 기본적으로 다음 내용이 포함됩니다.

<?php
return [
    &#39;class&#39; => &#39;yii\db\Connection&#39;,
    &#39;dsn&#39; => &#39;mysql:host=localhost;dbname=yii2basic&#39;,
    &#39;username&#39; => &#39;root&#39;,
    &#39;password&#39; => &#39;&#39;,
    &#39;charset&#39; => &#39;utf8&#39;,
];

config/db.php는 일반적인 파일 기반 구성 도구입니다. 이 파일은 데이터베이스 연결 yiidbConnection의 생성 및 초기화 매개변수를 구성합니다. 적용된 SQL 쿼리는 이 데이터베이스를 기반으로 합니다.

위에서 구성한 데이터베이스 연결은 Yii::$app->db 표현식을 통해 애플리케이션에서 접근할 수 있습니다.

信息: config/db.php 将被包含在应用配置文件 config/web.php 中, 后者指定了整个应用如何初始化。

Active Record 생성

Active Record 클래스를 상속받은 Country 클래스를 생성하여 models/Country.php 파일에 넣어 국가 테이블의 데이터를 표현하고 읽어옵니다.

<?php
namespace app\models;
use yii\db\ActiveRecord;
class Country extends ActiveRecord
{
}

이 Country 클래스는 yiidbActiveRecord에서 상속됩니다. 여기에는 코드를 작성할 필요가 없습니다. 지금과 마찬가지로 Yii는 클래스 이름을 기반으로 해당 데이터 테이블 이름을 추측할 수 있습니다.

信息: 如果类名和数据表名不能直接对应, 可以覆写 tableName() 方法去显式指定相关表名。

다음 코드와 같이 Country 클래스를 사용하여 국가 테이블 데이터를 쉽게 조작할 수 있습니다.

use app\models\Country;
// 获取 country 表的所有行并以 name 排序
$countries = Country::find()->orderBy(&#39;name&#39;)->all();
// 获取主键为 “US” 的行
$country = Country::findOne(&#39;US&#39;);
// 输出 “United States”
echo $country->name;
// 修改 name 为 “U.S.A.” 并在数据库中保存更改
$country->name = &#39;U.S.A.&#39;;
$country->save();

정보: 활성 레코드는 데이터베이스 데이터에 액세스하고 조작하는 객체 지향적이고 강력한 방법입니다. 활동 로깅 장에서 자세히 알아볼 수 있습니다. 또한 데이터 액세스 개체라는 또 다른 기본 메서드를 사용하여 데이터베이스 데이터를 조작할 수도 있습니다.

액션 만들기

국가 데이터를 최종 사용자에게 표시하려면 액션을 만들어야 합니다. 이전 섹션에서 마스터한 사이트 컨트롤러에서의 생성 작업과 비교하면 여기에서 모든 국가 관련 데이터에 대한 새 컨트롤러를 생성하는 것이 더 합리적입니다. 새 컨트롤러의 이름을 CountryController로 지정하고 다음과 같이 그 안에 인덱스 작업을 만듭니다.

<?php

namespace app\controllers;

use yii\web\Controller;
use yii\data\Pagination;
use app\models\Country;

class CountryController extends Controller
{
    public function actionIndex()
    {
        $query = Country::find();

        $pagination = new Pagination([
            &#39;defaultPageSize&#39; => 5,
            &#39;totalCount&#39; => $query->count(),
        ]);

        $countries = $query->orderBy(&#39;name&#39;)
            ->offset($pagination->offset)
            ->limit($pagination->limit)
            ->all();

        return $this->render(&#39;index&#39;, [
            &#39;countries&#39; => $countries,
            &#39;pagination&#39; => $pagination,
        ]);
    }
}

위 코드를 Controllers/CountryController.php 파일에 저장합니다.

index 작업은 활성 레코드 Country::find() 메서드를 호출하여 쿼리 문을 생성하고 국가 테이블에서 모든 데이터를 검색합니다. 요청당 반환되는 국가 수를 제한하기 위해 쿼리는 yiidataPagination 개체의 도움으로 페이지가 매겨집니다. Pagination 개체에는 두 가지 주요 임무가 있습니다.

SQL 쿼리 문의 오프셋 및 제한 절을 설정하여 각 요청이 한 페이지의 데이터만 반환하도록 합니다(이 예에서는 각 페이지가 5행입니다).

다음 단락에서 설명할 페이지 번호 목록으로 구성된 페이지네이터를 뷰에 표시합니다.

코드 끝에서 인덱스 작업은 index라는 뷰를 렌더링하고 국가 데이터와 페이징 정보를 여기에 전달합니다.

뷰 만들기

먼저 views 디렉터리 아래에 country라는 하위 디렉터리를 만듭니다. 이 디렉토리는 국가 컨트롤러가 렌더링한 모든 보기를 저장합니다. views/country 디렉토리에 다음 내용으로 index.php라는 뷰 파일을 만듭니다.

<?php
use yii\helpers\Html;
use yii\widgets\LinkPager;
?>
<h1>Countries</h1>
<ul>
<?php foreach ($countries as $country): ?>
    <li>
        <?= Html::encode("{$country->name} ({$country->code})") ?>:
        <?= $country->population ?>
    </li>
<?php endforeach; ?>
</ul>

<?= LinkPager::widget([&#39;pagination&#39; => $pagination]) ?>

이 뷰에는 국가 데이터를 표시하는 두 부분이 포함되어 있습니다. 첫 번째 부분은 국가 데이터를 반복하여 정렬되지 않은 HTML 목록으로 렌더링합니다. 두 번째 부분에서는 yiiwidgetsLinkPager를 사용하여 작업에서 전달된 페이징 정보를 렌더링합니다. LinkPager 위젯은 페이징 버튼 목록을 표시합니다. 아무 버튼이나 클릭하면 해당 페이지로 이동합니다.

테스트 실행

다음 URL로 브라우저를 방문하여 작동하는지 확인하세요.

http://hostname/index.php?r=country/index

yii 프레임워크를 데이터베이스에 연결하는 방법

위 내용은 yii 프레임워크를 데이터베이스에 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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