首頁 >php框架 >Laravel >laravel資料遷移與Eloquent ORM的詳細介紹(程式碼範例)

laravel資料遷移與Eloquent ORM的詳細介紹(程式碼範例)

不言
不言轉載
2019-01-08 11:34:173637瀏覽

這篇文章帶給大家的內容是關於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資料遷移與Eloquent ORM的詳細介紹(程式碼範例)

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

定義中間件

定義一個全域中間件,每個要求都會被執行。執行 php artisan make:middleware BrowseLog,建立了 app/Http/Middleware/BrowseLog.php  檔案。
將建立好的中間件加入到app/Http/Kernel.php 中,如下

laravel資料遷移與Eloquent ORM的詳細介紹(程式碼範例)

#記錄資料

最後在中間件中,記錄資料到資料庫即可,程式碼如下

/**
     * 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的詳細介紹(程式碼範例)

資料寫入正常,本次的範例就到此為止。

#

以上是laravel資料遷移與Eloquent ORM的詳細介紹(程式碼範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除