laravel 數(shù)據(jù)遷移與 Eloquent ORM的實現(xiàn)方法
導(dǎo)語
數(shù)據(jù)庫可以說是后端開發(fā)最常用,也是最重要的部分。laravel 提供了很實用的 Eloquent ORM 模型類,簡單、直觀的與數(shù)據(jù)庫進(jìn)行交互。同時使用數(shù)據(jù)遷移管理數(shù)據(jù)庫,可以與團(tuán)隊進(jìn)行共享以及編輯。二者的更多介紹請查看下方的文檔。
以下使用二者進(jìn)行示例,需求是記錄用戶瀏覽記錄。請勿將本示例帶入實際項目中,本文僅作示例。實際項目根據(jù)需求進(jìn)行記錄,以及選擇存儲方式。
創(chuàng)建數(shù)據(jù)表
第一步當(dāng)然是創(chuàng)建數(shù)據(jù)表了。使用 artisan 命令可以很方便的創(chuàng)建模型以及數(shù)據(jù)遷移。php artisan make:model Models/BrowseLog -m,-m 參數(shù)在創(chuàng)建模型的同時也創(chuàng)建了數(shù)據(jù)遷移文件。執(zhí)行過上述命令后,新增了 app/Models/BrowseLog.php 以及 database/migrations/{now_date}_create_browse_logs_table.php 兩個文件。
接下來編輯 {now_date}_create_browse_logs_table.php 來創(chuàng)建數(shù)據(jù)表
/**
* 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('根據(jù) ip 獲取城市名稱');
$table->timestamps();
});
DB::statement("ALTER TABLE `browse_logs` comment'瀏覽記錄表'"); // 表注釋
}
代碼如上,編輯完成后,執(zhí)行命令 php artisan migrate 會將所有未執(zhí)行遷移的數(shù)據(jù)表創(chuàng)建。如下

個人感覺,laravel 默認(rèn)的數(shù)據(jù)類型值得商榷。例如 ipAddress(),數(shù)據(jù)格式為 varchar(45),其實可以使用 ip2long 轉(zhuǎn)換成 int 進(jìn)行存儲。timestamps() 也可以使用時間戳進(jìn)行存儲。當(dāng)然 laravel 也提供了 訪問器 & 修改器 方便維護(hù)。各位實際項目中自行選擇。
定義中間件
定義一個全局中間件,每一次請求都會被執(zhí)行。執(zhí)行 php artisan make:middleware BrowseLog,創(chuàng)建了 app/Http/Middleware/BrowseLog.php 文件。
將創(chuàng)建好的中間件添加到 app/Http/Kernel.php 中,如下

記錄數(shù)據(jù)
最后在中間件中,記錄數(shù)據(jù)到數(shù)據(jù)庫即可,代碼如下
/**
* 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);
}
訪問幾個鏈接后,去數(shù)據(jù)庫看下

數(shù)據(jù)寫入正常,本次的示例就到此為止。
參考資料:數(shù)據(jù)庫操作 —— 遷移、Eloquent ORM —— 快速入門。
- Laravel框架數(shù)據(jù)庫遷移操作實例詳解
- laravel解決遷移文件一次刪除創(chuàng)建字段報錯的問題
- laravel 執(zhí)行遷移回滾示例
- Laravel5.5 數(shù)據(jù)庫遷移:創(chuàng)建表與修改表示例
- 關(guān)于laravel 數(shù)據(jù)庫遷移中integer類型是無法指定長度的問題
- Laravel5.7 數(shù)據(jù)庫操作遷移的實現(xiàn)方法
- 詳細(xì)Laravel5.5執(zhí)行表遷移命令出現(xiàn)表為空的解決方案
- Laravel中數(shù)據(jù)遷移與數(shù)據(jù)填充的詳細(xì)步驟
- Laravel實現(xiàn)數(shù)據(jù)庫遷移與支持中文的填充
- Laravel 的數(shù)據(jù)庫遷移的方法
- Laravel 5框架學(xué)習(xí)之?dāng)?shù)據(jù)庫遷移(Migrations)
- 使用git遷移Laravel項目至新開發(fā)環(huán)境的步驟詳解
相關(guān)文章
CI框架學(xué)習(xí)筆記(二) -入口文件index.php
本文介紹的是CI框架的入口文件index.php的相關(guān)資料,需要的朋友可以參考下2014-10-10
laravel5.4利用163郵箱發(fā)送郵件的步驟詳解
發(fā)送郵件是我們?nèi)粘T陂_發(fā)中必不可少會遇到的一個需求,下面這篇文章主要給大家介紹了關(guān)于laravel5.4利用163郵箱發(fā)送郵件的步驟,文中通過示例代碼和圖片介紹的非常詳細(xì),需要的朋友可以參考下。2017-09-09
從零開始學(xué)YII2框架(二)通過 Composer 安裝擴(kuò)展插件
在使用Yii框架開發(fā)的過程中,有一些優(yōu)秀的插件可以讓我們事半功倍。下面來介紹通過Composer安裝Yii2插件的方法。2014-08-08
基于Laravel Auth自定義接口API用戶認(rèn)證的實現(xiàn)方法
這篇文章主要給大家介紹了基于Laravel Auth自定義接口API用戶認(rèn)證的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07

