主頁 > 知識(shí)庫 > laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法

laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法

熱門標(biāo)簽:抖音有個(gè)地圖標(biāo)注是什么意思 保定crm外呼系統(tǒng)運(yùn)營商 九江外呼系統(tǒng) 七魚外呼系統(tǒng)停用嗎 智能電話機(jī)器人排名前十名南京 西區(qū)企業(yè)怎么做地圖標(biāo)注入駐 地下城堡2圖九地圖標(biāo)注 海南人工外呼系統(tǒng)有效果嗎 阿里云400電話申請(qǐng)加工單

導(dǎo)語

數(shù)據(jù)庫可以說是后端開發(fā)最常用,也是最重要的部分。laravel 提供了很實(shí)用的 Eloquent ORM 模型類,簡單、直觀的與數(shù)據(jù)庫進(jìn)行交互。同時(shí)使用數(shù)據(jù)遷移管理數(shù)據(jù)庫,可以與團(tuán)隊(duì)進(jìn)行共享以及編輯。二者的更多介紹請(qǐng)查看下方的文檔。
以下使用二者進(jìn)行示例,需求是記錄用戶瀏覽記錄。請(qǐng)勿將本示例帶入實(shí)際項(xiàng)目中,本文僅作示例。實(shí)際項(xiàng)目根據(jù)需求進(jìn)行記錄,以及選擇存儲(chǔ)方式。

創(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)建模型的同時(shí)也創(chuàng)建了數(shù)據(jù)遷移文件。執(zhí)行過上述命令后,新增了 app/Models/BrowseLog.php 以及 database/migrations/{now_date}_create_browse_logs_table.php 兩個(gè)文件。
接下來編輯 {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('請(qǐng)求 url');
   $table->char('city_name', 10)->comment('根據(jù) ip 獲取城市名稱');
   $table->timestamps();
  });

  DB::statement("ALTER TABLE `browse_logs` comment'瀏覽記錄表'"); // 表注釋
 }

代碼如上,編輯完成后,執(zhí)行命令 php artisan migrate 會(huì)將所有未執(zhí)行遷移的數(shù)據(jù)表創(chuàng)建。如下

個(gè)人感覺,laravel 默認(rèn)的數(shù)據(jù)類型值得商榷。例如 ipAddress(),數(shù)據(jù)格式為 varchar(45),其實(shí)可以使用 ip2long 轉(zhuǎn)換成 int 進(jìn)行存儲(chǔ)。timestamps() 也可以使用時(shí)間戳進(jìn)行存儲(chǔ)。當(dāng)然 laravel 也提供了 訪問器 修改器 方便維護(hù)。各位實(shí)際項(xiàng)目中自行選擇。

定義中間件

定義一個(gè)全局中間件,每一次請(qǐng)求都會(huì)被執(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);
 }

訪問幾個(gè)鏈接后,去數(shù)據(jù)庫看下

數(shù)據(jù)寫入正常,本次的示例就到此為止。

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

您可能感興趣的文章:
  • Laravel框架數(shù)據(jù)庫遷移操作實(shí)例詳解
  • laravel解決遷移文件一次刪除創(chuàng)建字段報(bào)錯(cuò)的問題
  • laravel 執(zhí)行遷移回滾示例
  • Laravel5.5 數(shù)據(jù)庫遷移:創(chuàng)建表與修改表示例
  • 關(guān)于laravel 數(shù)據(jù)庫遷移中integer類型是無法指定長度的問題
  • Laravel5.7 數(shù)據(jù)庫操作遷移的實(shí)現(xiàn)方法
  • 詳細(xì)Laravel5.5執(zhí)行表遷移命令出現(xiàn)表為空的解決方案
  • Laravel中數(shù)據(jù)遷移與數(shù)據(jù)填充的詳細(xì)步驟
  • Laravel實(shí)現(xiàn)數(shù)據(jù)庫遷移與支持中文的填充
  • Laravel 的數(shù)據(jù)庫遷移的方法
  • Laravel 5框架學(xué)習(xí)之?dāng)?shù)據(jù)庫遷移(Migrations)
  • 使用git遷移Laravel項(xiàng)目至新開發(fā)環(huán)境的步驟詳解

標(biāo)簽:九江 韶關(guān) 涼山 甘肅 遼陽 梅河口 昭通 十堰

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法》,本文關(guān)鍵詞  laravel,數(shù)據(jù),遷移,與,Eloquent,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章