laravel數據遷移與Eloquent ORM的詳細介紹

2019-10-15     科技i關注

本篇文章給大家帶來的內容是關於laravel 數據遷移與Eloquent ORM的詳細介紹(代碼示例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。

資料庫可以說是後端開發最常用,也是最重要的部分。laravel 提供了很實用的 Eloquent ORM 模型類,簡單、直觀的與資料庫進行交互。同時使用數據遷移管理資料庫,可以與團隊進行共享以及編輯。二者的更多介紹請查看下方的文檔。

以下使用二者進行示例,需求是記錄用戶瀏覽記錄。請勿將本示例帶入實際項目中,本文僅作示例。實際項目根據需求進行記錄,以及選擇存儲方式。

創建數據表

第一步當然是創建數據表了。使用 artisan 命令可以很方便的創建模型以及數據遷移。php artisan make:model Models/BrowseLog -m,-m 參數在創建模型的同時也創建了數據遷移文件。執行過上述命令後,新增了 app/Models/BrowseLog.php 以及 database/migrations/{now_date}_create_browse_logs_table.php 兩個文件。

接下來編輯 {now_date}_create_browse_logs_table.php 來創建數據表

/**

* Run the migrations.

*

* @return void

*/

public function up()

{

Schema::create('browse_logs', function (Blueprint $table) {

$table->increments('id');

$table->ipAddress('ip_addr')->comment('ip 地址');

$table->string('request_url', 20)->comment('請求 url');

$table->char('city_name', 10)->comment('根據 ip 獲取城市名稱');

$table->timestamps();

});

DB::statement("ALTER TABLE `browse_logs` comment'瀏覽記錄表'"); // 表注釋

}

代碼如上,編輯完成後,執行命令 php artisan migrate 會將所有未執行遷移的數據表創建。如下

個人感覺,laravel 默認的數據類型值得商榷。例如 ipAddress(),數據格式為 varchar(45),其實可以使用 ip2long 轉換成 int 進行存儲。timestamps() 也可以使用時間戳進行存儲。當然 laravel 也提供了 訪問器 & 修改器 方便維護。各位實際項目中自行選擇。

定義中間件

定義一個全局中間件,每一次請求都會被執行。執行 php artisan make:middleware BrowseLog,創建了 app/Http/Middleware/BrowseLog.php 文件。

將創建好的中間件添加到 app/Http/Kernel.php 中,如下

記錄數據

最後在中間件中,記錄數據到資料庫即可,代碼如下

/**

* Handle an incoming request.

*

* @param \\Illuminate\\Http\\Request $request

* @param \\Closure $next

* @return mixed

*/

public function handle($request, Closure $next)

{

$log = new \\App\\Models\\BrowseLog();

$log->ip_addr = $request->getClientIp();

$log->request_url = $request->path();

$log->city_name = get_city_by_ip();

$log->save();

return $next($request);

}

訪問幾個連結後,去資料庫看下

數據寫入正常,本次的示例就到此為止。

以上就是laravel數據遷移與Eloquent ORM的詳細介紹(代碼示例)的詳細內容,更多請關注其它相關文章!

更多技巧請《轉發 + 關注》哦!

文章來源: https://twgreatdaily.com/zh-cn/aY2rzG0BMH2_cNUgBQKz.html