이 글에서는 주로 PHP Yii 프레임워크의 데이터베이스 구성 및 SQL 작업 예제 튜토리얼을 소개합니다. Yii는 다양한 데이터베이스에 대한 바인딩을 지원합니다. 이 글에서는 주로 Yii의 다양한 쿼리문을 사용하는 예제를 제공합니다. to
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', ], ], // ... ];
$connection = \Yii::$app->db;
'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();
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();
// 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!