찾다
PHP 프레임워크YIIyii 프레임워크를 데이터베이스에 연결하는 방법

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 id="Countries">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으로 문의하세요.
YII의 특징 : 장점 검사YII의 특징 : 장점 검사Apr 27, 2025 am 12:03 AM

YII 프레임 워크는 PHP 프레임 워크에서 두드러지며 장점은 다음과 같습니다. 1. MVC 아키텍처 및 구성 요소 설계를위한 코드 구성 및 재사용 성을 향상시킵니다. 2. 개발 효율을 향상시키기위한 GII 코드 생성기 및 ActivereCord; 3. 성능을 최적화하기위한 다중 캐싱 메커니즘; 4. 권한 관리를 단순화하기위한 유연한 RBAC 시스템.

과대 광고 : 오늘 YII의 역할을 평가합니다과대 광고 : 오늘 YII의 역할을 평가합니다Apr 25, 2025 am 12:27 AM

YII는 개발자에게 강력한 선택으로 남아 있습니다. 1) YII는 MVC 아키텍처를 기반으로 한 고성능 PHP 프레임 워크이며 Activerecord, GII 및 캐시 시스템과 같은 도구를 제공합니다. 2) 장점에는 효율성과 유연성이 포함되지만 학습 곡선은 가파르고 지역 사회 지원은 비교적 제한적입니다. 3) 고성능과 유연성이 필요한 프로젝트에 적합하지만 팀 기술 스택 및 학습 비용을 고려하십시오.

YII 실행 : 현재 응용 프로그램 및 프로젝트YII 실행 : 현재 응용 프로그램 및 프로젝트Apr 24, 2025 am 12:03 AM

YII 프레임 워크는 엔터프라이즈 레벨 애플리케이션, 중소 규모 프로젝트 및 개별 프로젝트에 적합합니다. 1) Enterprise 수준의 응용 분야에서 YII의 고성능 및 확장 성은 전자 상거래 플랫폼과 같은 대규모 프로젝트에서 탁월합니다. 2) 중소 규모 프로젝트에서 YII의 GII 도구는 프로토 타입 및 MVP를 신속하게 구축하는 데 도움이됩니다. 3) 개인 및 오픈 소스 프로젝트에서 YII의 경량 기능은 소규모 웹 사이트 및 블로그에 적합합니다.

YII 사용 : 강력하고 확장 가능한 웹 솔루션 생성YII 사용 : 강력하고 확장 가능한 웹 솔루션 생성Apr 23, 2025 am 12:16 AM

YII 프레임 워크는 효율적이고 안전하며 확장 가능한 웹 응용 프로그램을 구축하는 데 적합합니다. 1) YII는 MVC 아키텍처를 기반으로하며 구성 요소 설계 및 보안 기능을 제공합니다. 2) 기본 CRUD 운영 및 고급 RESTFULAPI 개발을 지원합니다. 3) 로깅 및 디버깅 도구 모음과 같은 디버깅 기술을 제공하십시오. 4) 성능 최적화를 위해 캐시와 게으른로드를 사용하는 것이 좋습니다.

YII의 목적 : 웹 애플리케이션을 빠르고 효율적으로 구축합니다YII의 목적 : 웹 애플리케이션을 빠르고 효율적으로 구축합니다Apr 22, 2025 am 12:07 AM

YII의 목적은 개발자가 웹 애플리케이션을 빠르고 효율적으로 구축 할 수 있도록하는 것입니다. 구현은 다음 방법을 통해 구현됩니다. 1) 구성 요소 기반 설계 및 MVC 아키텍처를 통해 코드 유지 관리 및 재사용 성을 향상시킵니다. 2) GII 도구는 개발 속도를 향상시키기 위해 코드를 자동으로 생성합니다. 3) 게으른 하중 및 캐싱 메커니즘 최적화 성능; 4) 타사 라이브러리의 통합을 용이하게하기위한 유연한 확장 성; 5) 복잡한 비즈니스 로직을 처리하기 위해 RBAC 기능을 제공하십시오.

YII의 다양성 : 간단한 사이트에서 복잡한 프로젝트에 이르기까지YII의 다양성 : 간단한 사이트에서 복잡한 프로젝트에 이르기까지Apr 21, 2025 am 12:08 AM

yiiisversatileavssuitable projectsofallsof.1) 1) 간단한 사이트, yiioofferseasssetupandrapiddevelopment.2) forcomplexprojects, itmodularityandrbacsystemmanagescalability 및 security 효과.

YII와 PHP 프레임 워크의 미래YII와 PHP 프레임 워크의 미래Apr 20, 2025 am 12:11 AM

YII 프레임 워크는 미래의 PHP 프레임 워크 개발에서 중요한 역할을 계속할 것입니다. 1) YII는 효율적인 MVC 아키텍처, 강력한 ORM 시스템, 내장 캐싱 메커니즘 및 풍부한 확장 라이브러리를 제공합니다. 2) 구성 요소화 된 설계 및 유연성으로 인해 복잡한 비즈니스 논리 및 편안한 API 개발에 적합합니다. 3) YII는 마이크로 서비스 및 컨테이너 화와 같은 최신 PHP 기능 및 기술 트렌드에 적응하도록 지속적으로 업데이트됩니다.

YII 행동 : 실제 예제 및 응용 프로그램YII 행동 : 실제 예제 및 응용 프로그램Apr 19, 2025 am 12:03 AM

YII 프레임 워크는 모든 크기의 웹 애플리케이션을 개발하는 데 적합하며 장점은 고성능 및 풍부한 기능 세트에 있습니다. 1) YII는 MVC 아키텍처를 채택하며 핵심 구성 요소에는 ActiveRecord, Widget 및 GII 도구가 포함됩니다. 2) 요청 처리 프로세스를 통해 YII는 HTTP 요청을 효율적으로 처리합니다. 3) 기본 사용법은 컨트롤러와 뷰를 만드는 간단한 예를 보여줍니다. 4) Advanced Usage는 ActiveRecord를 통한 데이터베이스 작업의 유연성을 보여줍니다. 5) 디버깅 기술에는 디버그 도구 모음 및 로깅 시스템 사용이 포함됩니다. 6) 성능 최적화 캐시 및 데이터베이스 쿼리 최적화를 사용하고 코딩 사양 및 종속성 주입을 따라 코드 품질을 향상시키는 것이 좋습니다.

See all articles

핫 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 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

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

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구