国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

laravel 數據遷移與 Eloquent ORM

tulayang / 2189人閱讀

摘要:同時使用數據遷移管理數據庫,可以與團隊進行共享以及編輯。實際項目根據需求進行記錄,以及選擇存儲方式。使用命令可以很方便的創建模型以及數據遷移。,參數在創建模型的同時也創建了數據遷移文件。參考資料數據庫操作遷移快速入門。

導語

數據庫可以說是后端開發最常用,也是最重要的部分。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  IlluminateHttpRequest  $request
     * @param  Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        $log = new AppModelsBrowseLog();

        $log->ip_addr = $request->getClientIp();
        $log->request_url = $request->path();
        $log->city_name = get_city_by_ip();

        $log->save();

        return $next($request);
    }

訪問幾個鏈接后,去數據庫看下

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


參考資料:數據庫操作 —— 遷移、Eloquent ORM —— 快速入門。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29915.html

相關文章

  • laravel入門

    摘要:開發根目錄測試分為單元測試和功能測試創建一個文件執行測試測試前清除配置緩存運行單個測試用例小提示在開發與進行交互的第三方擴展包時,最好選擇注入契約而不使用。 參考https://laravelacademy.org/ 概念 單詞 契約Contract 就是接口 repository 倉庫(封裝數據訪問,可以搜索:repository模式) Container 容器 ServicePr...

    韓冰 評論0 收藏0
  • Laravel 5 系列入門教程(一)【最適合中國人的 Laravel 教程】

    摘要:原文發表在我的個人網站系列入門教程一最適合中國人的教程本教程示例代碼見大家在任何地方卡住,最快捷的解決方式就是去看我的示例代碼。在此我推薦一個全量中國鏡像。 原文發表在我的個人網站:Laravel 5 系列入門教程(一)【最適合中國人的 Laravel 教程】 本教程示例代碼見:https://github.com/johnlui/Learn-Laravel-5 大...

    EscapedDog 評論0 收藏0
  • PHP 項目中單獨使用 Laravel Eloquent 查詢語句來避免 SQL 注入

    摘要:是一個記錄當前應用所受威脅情況的項目。怎么做呢用參數化查詢對數據格式化,并使查詢語句與數據分離。使用參數化查詢,可以確保程序遠離注入風險。例子如下除此之外,還有一種安全的做法,就是在項目中使用對象關系映射或者是查詢構造器。 showImg(https://segmentfault.com/img/remote/1460000018641613?w=1680&h=859); OWASP?...

    dayday_up 評論0 收藏0
  • 【日常手記】之Laravel5.3

    摘要:個人網站最近剛寫了一個手機在線播放的電影站使用日常手記更新使用的的查詢作用域的本地作用域去自定義可復用的約束集合,方便鏈式調用什么是本地查詢作用域本地作用域允許我們定義通用的約束集合以便在應用中復用。 關于作者 程序開發人員,不拘泥于語言與技術,目前主要從事PHP和前端開發,使用Laravel和VueJs,App端使用Apicloud混合式開發。合適和夠用是最完美的追求。 個人網站:...

    kidsamong 評論0 收藏0
  • laravel5.5手寫教程4Eloquent ORM分頁及軟刪除

    摘要:從而達到了軟刪除。不過,你可以通過在查詢中調用方法來強制查詢已被軟刪除的模型方法也可以被用在關聯查詢只取出軟刪除數據會只取出軟刪除數據恢復被軟刪除的模型有時候你可能希望取消刪除一個已被軟刪除的模型。 Laravel 有三寶,路由、容器和 Eloquent ORM,Eloquent ORM。我個人一直比較推薦于在實際操作中學習,之前簡單了解了路由和Eloquent ORM的基本用法,今天...

    mindwind 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<