一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - PHP教程 - laravel 數據遷移與 Eloquent ORM的實現方法

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

2021-08-01 14:43haoyq PHP教程

laravel 提供了很實用的 Eloquent ORM 模型類,簡單、直觀的與數據庫進行交互。同時使用數據遷移管理數據庫,可以與團隊進行共享以及編輯,本文詳細的介紹了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 來創建數據表

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
/**
  * 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的實現方法

記錄數據

最后在中間件中,記錄數據到數據庫即可,代碼如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
/**
  * 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的實現方法

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

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

原文鏈接:https://segmentfault.com/a/1190000017792631

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美亚洲国产另类在线观看 | 亚洲高清一区二区三区久久 | free性丰满hd性欧美人体 | 黑人巨大和日本娇小中出 | 99久久精品国内 | 91小视频在线观看免费版高清 | 变态np虐高h | 青青热久免费精品视频精品 | 亚洲福利区 | 亚洲精品乱码久久久久久蜜桃图片 | 无码骚夜夜精品 | a性片 | 高h生子双性美人受 | 国产日韩综合 | 成人人免费夜夜视频观看 | jj视频免费看 | 午夜看片a福利在线观看 | 国产成人精品一区二区仙踪林 | mm131亚洲精品久久 | 久久国产免费 | 国产一级在线免费观看 | 亚洲人成伊人成综合网久久 | 狠狠撸在线播放 | 波多野结衣之双方调教在线观看 | 久久re热在线视频精99 | 免费jizz在在线播放国产 | 91小视频在线观看免费版高清 | 特黄特a级特别特级特毛片 特黄a级三级三级野战 | 日韩免费观看成第15集 | 牛人国产偷窥女洗浴在线观看 | 国产成人综合手机在线播放 | 亚洲精品国产成人 | 9久热这里只有精品视频在线观看 | 成人免费淫片95视频观看网站 | 色淫影院 | 肉文高h调教| 国产亚洲精品一区二区在线播放 | 国产成人www免费人成看片 | 日产精品卡一卡2卡三卡乱码工厂 | 亚洲人成影院午夜网站 | 亚洲欧美国产另类 |