亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2019年04月12日 09:58:16   作者:haoyq  
laravel 提供了很實(shí)用的 Eloquent ORM 模型類,簡(jiǎn)單、直觀的與數(shù)據(jù)庫(kù)進(jìn)行交互。同時(shí)使用數(shù)據(jù)遷移管理數(shù)據(jù)庫(kù),可以與團(tuán)隊(duì)進(jìn)行共享以及編輯,本文詳細(xì)的介紹了laravel 數(shù)據(jù)遷移與 Eloquent ORM的實(shí)現(xiàn)方法,感興趣的可以了解一下

導(dǎo)語(yǔ)

數(shù)據(jù)庫(kù)可以說(shuō)是后端開(kāi)發(fā)最常用,也是最重要的部分。laravel 提供了很實(shí)用的 Eloquent ORM 模型類,簡(jiǎn)單、直觀的與數(shù)據(jù)庫(kù)進(jìn)行交互。同時(shí)使用數(shù)據(jù)遷移管理數(shù)據(jù)庫(kù),可以與團(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í)行過(guò)上述命令后,新增了 app/Models/BrowseLog.php 以及 database/migrations/{now_date}_create_browse_logs_table.php 兩個(gè)文件。
接下來(lái)編輯 {now_date}_create_browse_logs_table.php 來(lái)創(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è)人感覺(jué),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 也提供了 訪問(wèn)器 & 修改器 方便維護(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ù)庫(kù)即可,代碼如下

/**
  * 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);
 }

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

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

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

相關(guān)文章

  • laravel實(shí)現(xiàn)查詢最后執(zhí)行的一條sql語(yǔ)句的方法

    laravel實(shí)現(xiàn)查詢最后執(zhí)行的一條sql語(yǔ)句的方法

    今天小編就為大家分享一篇laravel實(shí)現(xiàn)查詢最后執(zhí)行的一條sql語(yǔ)句的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • 批量去除PHP文件中bom的PHP代碼

    批量去除PHP文件中bom的PHP代碼

    今天搜索查看網(wǎng)頁(yè)源碼時(shí)為什么開(kāi)頭會(huì)有空行這個(gè)問(wèn)題時(shí)找到的,批量去除PHP文件中bom的PHP代碼
    2012-03-03
  • php 404錯(cuò)誤頁(yè)面實(shí)現(xiàn)代碼

    php 404錯(cuò)誤頁(yè)面實(shí)現(xiàn)代碼

    如果訪問(wèn)您站點(diǎn)的用戶由于各種原因暫時(shí)出現(xiàn)無(wú)法訪問(wèn)頁(yè)面的錯(cuò)誤,如何給他一個(gè)友好的答復(fù),并且你也知道發(fā)生了這個(gè)錯(cuò)誤,看看下面這段程序,是用來(lái)定制404錯(cuò)誤頁(yè)面和發(fā)通知給網(wǎng)管。
    2009-06-06
  • symfony3.4中根據(jù)角色不同跳轉(zhuǎn)不同頁(yè)面功能

    symfony3.4中根據(jù)角色不同跳轉(zhuǎn)不同頁(yè)面功能

    這篇文章主要介紹了symfony3.4中根據(jù)角色不同跳轉(zhuǎn)不同頁(yè)面,在Symfony?3.4中,可以使用安全組件來(lái)實(shí)現(xiàn)控制不同角色跳轉(zhuǎn)到不同頁(yè)面的功能,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08
  • php實(shí)現(xiàn)微信支付之企業(yè)付款

    php實(shí)現(xiàn)微信支付之企業(yè)付款

    這篇文章主要為大家詳細(xì)介紹了php實(shí)現(xiàn)微信支付之企業(yè)付款功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • laravel框架實(shí)現(xiàn)為 Blade 模板引擎添加新文件擴(kuò)展名操作示例

    laravel框架實(shí)現(xiàn)為 Blade 模板引擎添加新文件擴(kuò)展名操作示例

    這篇文章主要介紹了laravel框架實(shí)現(xiàn)為 Blade 模板引擎添加新文件擴(kuò)展名操作,結(jié)合實(shí)例形式詳細(xì)分析了laravel框架Blade 模板引擎添加新文件擴(kuò)展名具體操作步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2020-01-01
  • laravel開(kāi)發(fā)中跨域的解決方案

    laravel開(kāi)發(fā)中跨域的解決方案

    最近在開(kāi)發(fā)中遇到了跨域的需求,通過(guò)查找相關(guān)資料找到了相關(guān)的解決方法了,所以下面這篇文章主要給大家介紹了關(guān)于laravel開(kāi)發(fā)中跨域的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-10-10
  • PHP處理二進(jìn)制數(shù)據(jù)的實(shí)現(xiàn)方法

    PHP處理二進(jìn)制數(shù)據(jù)的實(shí)現(xiàn)方法

    下面小編就為大家?guī)?lái)一篇PHP處理二進(jìn)制數(shù)據(jù)的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-06-06
  • PHP Yii框架之表單驗(yàn)證規(guī)則大全

    PHP Yii框架之表單驗(yàn)證規(guī)則大全

    Yii是一個(gè)基于組件的高性能PHP框架,用于開(kāi)發(fā)大型Web應(yīng)用。Yii采用嚴(yán)格的OOP編寫,并有著完善的庫(kù)引用以及全面的教程,本文給大家介紹php yii框架之表單驗(yàn)證規(guī)則大全,感興趣的朋友一起學(xué)習(xí)吧
    2015-11-11
  • ThinkPHP3.2.3框架實(shí)現(xiàn)執(zhí)行原生SQL語(yǔ)句的方法示例

    ThinkPHP3.2.3框架實(shí)現(xiàn)執(zhí)行原生SQL語(yǔ)句的方法示例

    這篇文章主要介紹了ThinkPHP3.2.3框架實(shí)現(xiàn)執(zhí)行原生SQL語(yǔ)句的方法,結(jié)合實(shí)例形式分析了thinkPHP3.2.3框架針對(duì)查詢、添加、修改、刪除等原生SQL操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-04-04

最新評(píng)論