Yii數據庫訪問(MySQL,MSSQL,SQLite,MariaDB,PostgreSQL,ORACLE)

Yii DAO(數據庫訪問對象)提供了訪問數據庫的API。Yii可訪問 數據庫(MySQL,MSSQL,SQLite,MariaDB,PostgreSQL,ORACLE)。它也可作爲其他數據庫訪問方法的基礎:活動記錄和查詢生成器。

Yii DAO支持以下數據庫 -

  • MySQL
  • MSSQL
  • SQLite
  • MariaDB
  • PostgreSQL
  • ORACLE
  • CUBRID

創建數據庫連接


第1步 - 創建一個數據庫連接,需要創建 yii\db\Connection 類的一個實例。

$mydb = new yii\db\Connection([
'dsn' => 'mysql:host=localhost;dbname=mydb',
'username' => 'username',
'password' => 'password',
'charset' => 'utf8',
]);

一般的做法是在應用程序組件內部配置數據庫連接。例如,在基本的應用程序模板數據庫連接配置位於 config/db.php 文件中,如下面的代碼。

'yii\\db\\Connection', 'dsn' => 'mysql:host = localhost;dbname = helloworld', 'username' => 'vladimir', 'password' => '123574896', 'charset' => 'utf8', \]; ?>

第2步 - 可以使用這個表達式訪問數據庫連接。

Yii::$app->db

要配置數據庫連接,則應該通過 DSN 屬性來指定其 DSN(數據源名稱)。DSN格式是根據不同的數據庫而不同的 -

  • MySQL, MariaDB − mysql:host = localhost;dbname = mydb

  • PostgreSQL − pgsql:host = localhost;port = 5432;dbname = mydb

  • SQLite − sqlite:/path/to/db/file

  • MS SQL Server (via sqlsrv driver) − sqlsrv:Server = localhost;Database = mydb

  • MS SQL Server (via mssql driver) − mssql:host = localhost;dbname = mydb

  • MS SQL Server (via dblib driver) − dblib:host = localhost;dbname = mydb

  • CUBRID − cubrid:dbname = mydb;host = localhost;port = 33000

  • Oracle − oci:dbname = //localhost:1521/mydb

要在動作中使用數據庫查詢操作,我們需要準備一些數據。

準備數據庫


第1步 - 創建一個新的數據庫。數據庫可以通過以下兩種方式進行。

  • 在終端運行 mysql -u root –p

  • 登錄數據後,通過執行 CREATE DATABASE mystudy CHARACTER SET utf8 COLLATE utf8_general_ci; 創建一個新的數據庫;

第2步 - 在 config/db.php 文件中配置數據庫連接。下面的配置可根據自己的實際情況配置。

'yii\\db\\Connection', 'dsn' => 'mysql:host = localhost;dbname = mystudy', 'username' => 'root', 'password' => '', 'charset' => 'utf8', \]; ?>

第3步 - 在項目根文件夾執行:yii migrate/create test_table 。此命令將用於創建管理數據庫數據庫遷移。 migrations文件會出現在項目的根的 migrations 文件夾中。
Yii數據庫訪問

第4步 - 修改遷移文件(在本示例中生成的是:m160529_014611_test_table.php),並使用以下這些代碼。

createTable("user", \[ "id" => Schema::TYPE\_PK, "name" => Schema::TYPE\_STRING, "email" => Schema::TYPE\_STRING, \]); $this->batchInsert("user", \["name", "email"\], \[ \["User1", "user11@gmail.com"\], \["User2", "user22@gmail.com"\], \["User3", "user33@gmail.com"\], \["User4", "user44@gmail.com"\], \["User5", "user55@gmail.com"\], \["User6", "user66@gmail.com"\], \["User7", "user77@gmail.com"\], \["User8", "user88@gmail.com"\], \["User9", "user99@gmail.com"\], \["User10", "user1010@gmail.com"\], \["User11", "user1111@gmail.com"\], \]); } public function down() { //$this->dropTable('user'); } } ?>

上述遷移創建用戶表,它包含了以下這些字段:id, name, 和 email。它還增加了一些演示用戶帳號。

第5步 - 在項目的根目錄內運行: yii migrate  來遷移應用到數據庫。執行結果如下圖所示:

Yii數據庫訪問(MySQL,MSSQL,SQLite,MariaDB,PostgreSQL,ORACLE)

第6步-現在,我們需要爲user表創建模型。爲了簡便起見,我們將使用GII代碼生成工具。在瀏覽器中打開 url: http://localhost:8080/index.php?r=gii 。
然後,點擊 「Model generator」 下的 「Start」按鈕。 填寫表名(「user」)和模型類(「MyUser」),單擊「Preview」按鈕,最後點擊 「Generate」 按鈕。

Yii數據庫訪問(MySQL,MSSQL,SQLite,MariaDB,PostgreSQL,ORACLE)

Yii數據庫訪問(MySQL,MSSQL,SQLite,MariaDB,PostgreSQL,ORACLE)
MyUser 文件憶經生成在 models 目錄。