導語
數據庫可以說是后端開發最常用,也是最重要的部分。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 默認的數據類型值得商榷。例如 ipaddress()
,數據格式為 varchar(45)
,其實可以使用 ip2long
轉換成 int
進行存儲。timestamps()
也可以使用時間戳進行存儲。當然 laravel 也提供了 訪問器 & 修改器 方便維護。各位實際項目中自行選擇。
定義中間件
定義一個全局中間件,每一次請求都會被執行。執行 php artisan make:middleware browselog
,創建了 app/http/middleware/browselog.php
文件。
將創建好的中間件添加到 app/http/kernel.php
中,如下
記錄數據
最后在中間件中,記錄數據到數據庫即可,代碼如下
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 ); } |
訪問幾個鏈接后,去數據庫看下
數據寫入正常,本次的示例就到此為止。
參考資料:數據庫操作 —— 遷移、Eloquent ORM —— 快速入門。
原文鏈接:https://segmentfault.com/a/1190000017792631