婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > laravel 數據遷移與 Eloquent ORM的實現方法

laravel 數據遷移與 Eloquent ORM的實現方法

熱門標簽:抖音有個地圖標注是什么意思 保定crm外呼系統運營商 九江外呼系統 七魚外呼系統停用嗎 智能電話機器人排名前十名南京 西區企業怎么做地圖標注入駐 地下城堡2圖九地圖標注 海南人工外呼系統有效果嗎 阿里云400電話申請加工單

導語

數據庫可以說是后端開發最常用,也是最重要的部分。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);
 }

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

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

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

您可能感興趣的文章:
  • Laravel框架數據庫遷移操作實例詳解
  • laravel解決遷移文件一次刪除創建字段報錯的問題
  • laravel 執行遷移回滾示例
  • Laravel5.5 數據庫遷移:創建表與修改表示例
  • 關于laravel 數據庫遷移中integer類型是無法指定長度的問題
  • Laravel5.7 數據庫操作遷移的實現方法
  • 詳細Laravel5.5執行表遷移命令出現表為空的解決方案
  • Laravel中數據遷移與數據填充的詳細步驟
  • Laravel實現數據庫遷移與支持中文的填充
  • Laravel 的數據庫遷移的方法
  • Laravel 5框架學習之數據庫遷移(Migrations)
  • 使用git遷移Laravel項目至新開發環境的步驟詳解

標簽:九江 韶關 涼山 甘肅 遼陽 梅河口 昭通 十堰

巨人網絡通訊聲明:本文標題《laravel 數據遷移與 Eloquent ORM的實現方法》,本文關鍵詞  laravel,數據,遷移,與,Eloquent,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《laravel 數據遷移與 Eloquent ORM的實現方法》相關的同類信息!
  • 本頁收集關于laravel 數據遷移與 Eloquent ORM的實現方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 麻阳| 陇南市| 晴隆县| 昌江| 厦门市| 罗田县| 静海县| 鄢陵县| 平邑县| 彭泽县| 罗江县| 怀宁县| 庆云县| 都安| 三河市| 灵璧县| 永泰县| 绥阳县| 崇左市| 息烽县| 桂阳县| 仲巴县| 乌鲁木齐县| 武陟县| 都昌县| 大埔区| 贵州省| 南昌市| 南皮县| 汶上县| 柏乡县| 罗甸县| 张家川| 德惠市| 满洲里市| 寻甸| 互助| 蓝田县| 东乌| 榆林市| 仁怀市|