摘要:同時(shí)使用數(shù)據(jù)遷移管理數(shù)據(jù)庫,可以與團(tuán)隊(duì)進(jìn)行共享以及編輯。實(shí)際項(xiàng)目根據(jù)需求進(jìn)行記錄,以及選擇存儲(chǔ)方式。使用命令可以很方便的創(chuàng)建模型以及數(shù)據(jù)遷移。,參數(shù)在創(chuàng)建模型的同時(shí)也創(chuàng)建了數(shù)據(jù)遷移文件。參考資料數(shù)據(jù)庫操作遷移快速入門。
導(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ǔ)方式。
第一步當(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ù)庫即可,代碼如下
/** * 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); }
訪問幾個(gè)鏈接后,去數(shù)據(jù)庫看下
數(shù)據(jù)寫入正常,本次的示例就到此為止。
參考資料:數(shù)據(jù)庫操作 —— 遷移、Eloquent ORM —— 快速入門。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/29915.html
摘要:開發(fā)根目錄測(cè)試分為單元測(cè)試和功能測(cè)試創(chuàng)建一個(gè)文件執(zhí)行測(cè)試測(cè)試前清除配置緩存運(yùn)行單個(gè)測(cè)試用例小提示在開發(fā)與進(jìn)行交互的第三方擴(kuò)展包時(shí),最好選擇注入契約而不使用。 參考https://laravelacademy.org/ 概念 單詞 契約Contract 就是接口 repository 倉庫(封裝數(shù)據(jù)訪問,可以搜索:repository模式) Container 容器 ServicePr...
摘要:原文發(fā)表在我的個(gè)人網(wǎng)站系列入門教程一最適合中國人的教程本教程示例代碼見大家在任何地方卡住,最快捷的解決方式就是去看我的示例代碼。在此我推薦一個(gè)全量中國鏡像。 原文發(fā)表在我的個(gè)人網(wǎng)站:Laravel 5 系列入門教程(一)【最適合中國人的 Laravel 教程】 本教程示例代碼見:https://github.com/johnlui/Learn-Laravel-5 大...
摘要:是一個(gè)記錄當(dāng)前應(yīng)用所受威脅情況的項(xiàng)目。怎么做呢用參數(shù)化查詢對(duì)數(shù)據(jù)格式化,并使查詢語句與數(shù)據(jù)分離。使用參數(shù)化查詢,可以確保程序遠(yuǎn)離注入風(fēng)險(xiǎn)。例子如下除此之外,還有一種安全的做法,就是在項(xiàng)目中使用對(duì)象關(guān)系映射或者是查詢構(gòu)造器。 showImg(https://segmentfault.com/img/remote/1460000018641613?w=1680&h=859); OWASP?...
摘要:個(gè)人網(wǎng)站最近剛寫了一個(gè)手機(jī)在線播放的電影站使用日常手記更新使用的的查詢作用域的本地作用域去自定義可復(fù)用的約束集合,方便鏈?zhǔn)秸{(diào)用什么是本地查詢作用域本地作用域允許我們定義通用的約束集合以便在應(yīng)用中復(fù)用。 關(guān)于作者 程序開發(fā)人員,不拘泥于語言與技術(shù),目前主要從事PHP和前端開發(fā),使用Laravel和VueJs,App端使用Apicloud混合式開發(fā)。合適和夠用是最完美的追求。 個(gè)人網(wǎng)站:...
摘要:從而達(dá)到了軟刪除。不過,你可以通過在查詢中調(diào)用方法來強(qiáng)制查詢已被軟刪除的模型方法也可以被用在關(guān)聯(lián)查詢只取出軟刪除數(shù)據(jù)會(huì)只取出軟刪除數(shù)據(jù)恢復(fù)被軟刪除的模型有時(shí)候你可能希望取消刪除一個(gè)已被軟刪除的模型。 Laravel 有三寶,路由、容器和 Eloquent ORM,Eloquent ORM。我個(gè)人一直比較推薦于在實(shí)際操作中學(xué)習(xí),之前簡單了解了路由和Eloquent ORM的基本用法,今天...
閱讀 1679·2021-09-02 15:41
閱讀 1082·2021-09-02 15:11
閱讀 1360·2021-07-28 00:15
閱讀 2443·2019-08-30 15:55
閱讀 1225·2019-08-30 15:54
閱讀 1769·2019-08-30 15:54
閱讀 3043·2019-08-30 14:02
閱讀 2597·2019-08-29 16:57