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

angryTom
풀어 주다: 2019-11-04 14:15:58
원래의
2841명이 탐색했습니다.

이 글에서는 주로 PHP Yii 프레임워크의 데이터베이스 구성 및 SQL 작업 예제 튜토리얼을 소개합니다. Yii는 다양한 데이터베이스에 대한 바인딩을 지원합니다. 이 글에서는 주로 Yii의 다양한 쿼리문을 사용하는 예제를 제공합니다. to

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

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

Database Access(DAO)

Yii에는 PHP PDO 위에 구축된 DAO(데이터 액세스 계층)가 포함되어 있어 다른 데이터베이스와 통합된 데이터베이스를 제공합니다. ActiveRecord는 데이터베이스와 모델(MVC의 M, Model) 간의 상호 작용을 제공하고, DAO는 동적 쿼리 문을 생성하는 데 사용되며 다양한 위치에서 데이터베이스와 상호 작용하는 데 사용할 수 있는 간단하고 효율적인 SQL 쿼리를 제공합니다.

Yii는 기본적으로 다음 데이터베이스(DBMS)를 지원합니다:

MySQLMariaDBSQLitePostgreSQLCUBRID: 버전 >= 9.3(PHP PDO 확장의 버그로 인해 참조 값은 다음과 같습니다. 유효하지 않으므로 CUBRID의 클라이언트와 서버 모두에서 OracleMSSQL을 사용해야 합니다: Version>=2005.

1. Configuration#🎜🎜 # 데이터베이스 사용을 시작하려면 먼저 애플리케이션 구성에 db 구성요소를 추가하여 구현되는 데이터베이스 연결 구성요소를 구성해야 합니다("기본" 웹 애플리케이션은 config/web.php입니다). 데이터베이스 정보를 지정하는 데 사용되는 데이터 소스 이름입니다.

return [
  // ...
  'components' => [
    // ...
    'db' => [
      'class' => 'yii\db\Connection',
      'dsn' => 'mysql:host=localhost;dbname=mydatabase', // MySQL, MariaDB
      //'dsn' => 'sqlite:/path/to/database/file', // SQLite
      //'dsn' => 'pgsql:host=localhost;port=5432;dbname=mydatabase', // PostgreSQL
      //'dsn' => 'cubrid:dbname=demodb;host=localhost;port=33000', // CUBRID
      //'dsn' => 'sqlsrv:Server=localhost;Database=mydatabase', // MS SQL Server, sqlsrv driver
      //'dsn' => 'dblib:host=localhost;dbname=mydatabase', // MS SQL Server, dblib driver
      //'dsn' => 'mssql:host=localhost;dbname=mydatabase', // MS SQL Server, mssql driver
      //'dsn' => 'oci:dbname=//localhost:1521/mydatabase', // Oracle
      'username' => 'root', //数据库用户名
      'password' => '', //数据库密码
      'charset' => 'utf8',
    ],
  ],
  // ...
];
로그인 후 복사

2. 연결 구성 요소를 구성한 후 다음 구문을 사용하여 액세스할 수 있습니다.

$connection = \Yii::$app->db;
로그인 후 복사
ODBC를 통해 데이터베이스에 연결하려면 yiidbConnection::driverName 속성을 구성해야 합니다. 예:
'db' => [
  'class' => 'yii\db\Connection',
  'driverName' => 'mysql',
  'dsn' => 'odbc:Driver={MySQL};Server=localhost;Database=test',
  'username' => 'root',
  'password' => '',
],
로그인 후 복사

원하지 않는 경우 데이터베이스 연결을 전역 애플리케이션 구성 요소로 정의하면 코드에서 직접 초기화할 수 있습니다:

$connection = new \yii\db\Connection([
  'dsn' => $dsn,
   'username' => $username,
   'password' => $password,
]);
$connection->open();
로그인 후 복사

#🎜🎜 #3 연결을 생성한 후 추가 SQL 쿼리를 실행해야 하는 경우 다음을 추가할 수 있습니다. 다음 코드를 애플리케이션 구성 파일에 추가합니다.

return [
  // ...
  'components' => [
    // ...
    'db' => [
      'class' => 'yii\db\Connection',
      // ...
      'on afterOpen' => function($event) {
        $event->sender->createCommand("SET time_zone = 'UTC'")->execute();
      }
    ],
  ],
  // ...
];
로그인 후 복사

SQL을 실행해도 데이터가 반환되지 않으면 명령 실행 메서드를 사용할 수 있습니다.

$command = $connection->createCommand('UPDATE post SET status=1 WHERE id=1');
$command->execute();
로그인 후 복사
#🎜 🎜#삽입, 업데이트, 삭제 방법을 사용할 수 있습니다. 이러한 방법은 매개변수를 기반으로 적절한 SQL을 생성하고 실행합니다.

// INSERT
$connection->createCommand()->insert('user', [
  'name' => 'Sam',
  'age' => 30,
])->execute();
// INSERT 一次插入多行
$connection->createCommand()->batchInsert('user', ['name', 'age'], [
  ['Tom', 30],
  ['Jane', 20],
  ['Linda', 25],
])->execute();
// UPDATE
$connection->createCommand()->update('user', ['status' => 1], 'age > 30')->execute();
// DELETE
$connection->createCommand()->delete('user', 'status = 0')->execute();
로그인 후 복사

권장: "
YII tutorial

》#🎜 🎜#

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

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!