yii 프레임워크 구성 데이터베이스 연결
시작하기 전에 PHP PDO 확장과 사용 중인 데이터베이스(예: MySQL의 pdo_mysql)의 PDO 드라이버 를 설치했는지 확인하세요. 관계형 데이터베이스를 사용하기 위한 이것은 기본 요구 사항입니다. > (권장 학습: yii 프레임워크 )
드라이버와 확장 프로그램을 설치하고 사용할 수 있게 되면 config/db.php를 열고 내부의 구성 매개변수를 데이터베이스 구성에 맞게 수정하세요. 파일에는 기본적으로 다음 내용이 포함됩니다.
<?php return [ 'class' => 'yii\db\Connection', 'dsn' => 'mysql:host=localhost;dbname=yii2basic', 'username' => 'root', 'password' => '', 'charset' => 'utf8', ];
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('name')->all(); // 获取主键为 “US” 的行 $country = Country::findOne('US'); // 输出 “United States” echo $country->name; // 修改 name 为 “U.S.A.” 并在数据库中保存更改 $country->name = 'U.S.A.'; $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([ 'defaultPageSize' => 5, 'totalCount' => $query->count(), ]); $countries = $query->orderBy('name') ->offset($pagination->offset) ->limit($pagination->limit) ->all(); return $this->render('index', [ 'countries' => $countries, 'pagination' => $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(['pagination' => $pagination]) ?>
이 뷰에는 국가 데이터를 표시하는 두 부분이 포함되어 있습니다. 첫 번째 부분은 국가 데이터를 반복하여 정렬되지 않은 HTML 목록으로 렌더링합니다. 두 번째 부분에서는 yiiwidgetsLinkPager를 사용하여 작업에서 전달된 페이징 정보를 렌더링합니다. LinkPager 위젯은 페이징 버튼 목록을 표시합니다. 아무 버튼이나 클릭하면 해당 페이지로 이동합니다.
테스트 실행
다음 URL로 브라우저를 방문하여 작동하는지 확인하세요.
http://hostname/index.php?r=country/index
위 내용은 yii 프레임워크를 데이터베이스에 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

YII와 PHP는 동적 웹 사이트를 만들 수 있습니다. 1) YII는 웹 애플리케이션 개발을 단순화하는 고성능 PHP 프레임 워크입니다. 2) YII는 대규모 응용 프로그램 개발에 적합한 MVC 아키텍처, ORM, 캐시 및 기타 기능을 제공합니다. 3) YII의 기본 및 고급 기능을 사용하여 웹 사이트를 신속하게 구축하십시오. 4) 구성, 네임 스페이스 및 데이터베이스 연결 문제에주의를 기울이고 디버깅을 위해 로그 및 디버깅 도구를 사용하십시오. 5) 캐싱 및 최적화 쿼리를 통해 성능을 향상시키고 모범 사례를 따라 코드 품질을 향상시킵니다.

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

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

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

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

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

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

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


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.
