您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關使用laravel怎么實現數據遷移,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
創建數據表
第一步當然是創建數據表了。使用 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怎么實現數據遷移就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。