Laravel學習--關於Relation的坑

来源:http://www.cnblogs.com/CraryPrimitiveMan/archive/2016/08/21/5734683.html
-Advertisement-
Play Games

最近在用 Laravel 5.2,踩了幾個關於 Relation 的坑,記錄一下~~ ...


前段時間比較忙,就沒有堅持寫博客,但發現這周末再想撿起來,好難,一直到了今天晚上,才決定坐下來寫一篇,哈哈哈~~

最近在用 Laravel 5.2,踩了幾個關於 Relation 的坑,在這裡用博客記錄一下。

如果大家不瞭解 Laravel 的 Relation 的話,可以查看文檔Eloquent: Relationships

在資料庫中先創建兩張表 users 和 password_resets,分別代表用戶和重置密碼,假設他們的關係是一對多,一個用戶有多個重置密碼記錄。

我們可以使用 Laravel 提供的 migration 創建資料庫,具體可以查看文檔Database: Migrations

使用的users 表和 password_resets 表是預設創建的。

然後我們可以通過界面註冊一個用戶,也可以在 users 表中直接插入一條。password_resets 表中也插入幾條數據,這個也可以通過界面的忘記密碼添加。

然後創建好相應的Model,在 User.php 中,加入如下代碼:

public function passwordReset() {
    return $this->hasMany('App\PasswordReset', 'email', 'email');
}

在 Controller 中使用如下代碼:

$data = User::with('passwordReset')->get();
echo $data->toJson();
die;

這個時候你可以看到輸出的數據中的 password_reset 欄位是有內容的,但假如說你希望查找的 password_reset 中只有 token,寫法如下:

$data = User::with(['passwordReset' => function($query) {
    $query->select('token');
}])->get();

然後你會驚奇的發現輸出的數據中的 password_reset 欄位是一個空數組。

是不是覺得好神奇,當時我也是崩潰的,去查看源碼,發現原來,Relation 是通過兩條語句實現的,它會先查主表(users表),選出其中關聯的欄位(email欄位)組成數組,使用 in 語句去查詢關聯表(password_resets表),然後將查出來的數據根據關聯欄位相等,處理到一起。這裡需要註意的是查出來的兩塊數據關聯到一起是在 php 中實現的,所以,上面的語句由於沒有查出 password_resets表的 email 欄位,無法關聯到一起,其結果的 password_reset 欄位是一個預設值-空數組。

現在我們在 select 中加入 email 欄位,代碼如下:

$data = User::with(['passwordReset' => function($query) {
    $query->select('token', 'email');
}])->get();

然後你就會發現數據中的 password_reset 欄位有值了。

這是踩到的一個坑。

然後我們在來設置一下 PasswordReset.php 中設置一下主鍵,設置為 email 欄位(這裡可能不太合理,email 會重覆,這樣寫只是為了重現這個坑),代碼如下:

protected $primaryKey = 'email';

然後你又會驚奇的發現輸出的數據中的 password_reset 欄位又變成了一個空數組,這又是怎麼了?

原來 Laravel 5.2 為 Model 添加了一個屬性 $keyType,預設值是 int,這意味著它會將查出來的 email 欄位強轉成 int 類型,所以在匹配的時候,就有對不上了。

現在我們只需要在定義一下 $keyType 為 string 就可以了,在 PasswordReset.php 中添加如下代碼:

protected $keyType = 'string';

這是在 Laravel 5.0 升 5.2時踩到的坑。

Laravel 5.2,我也是剛開始看,如果上面有什麼不對的,歡迎大家指出~~

如果大家覺得這篇博客對你有所幫助的話,請點一下頂~~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文網址: http://www.cnblogs.com/csdev Networkcomms 是一款C# 語言編寫的TCP/UDP通信框架 作者是英國人 以前是收費的 目前作者已經開源 開源地址是:https://github.com/MarcFletcher/NetworkComms.Net 這 ...
  • 在C#4.0中,最核心的特性莫過於動態類型的引入。 1、動態類型簡介 一直在強調C#是一門靜態類型的語言,因為它在定義變數時要明確給出變數的類型。例如在int i=5;這樣的代碼中,int就是變數i的類型,如果定義變數時沒有明確指定變數的類型,則這樣的代碼是通過不了編譯的。 在C#4.0中,微軟引入 ...
  • 本文主要介紹cyq.data orm 框架中的log和syslogs兩個類的用法,詳情如下...... ...
  • 斷斷續續地學習了php有一段時間了,總是不能很好地理解,如今把數組和遍曆數組整理出來。 從基礎開始說起: php數組分為索引數組,和關係型數組, 索引數組就是下標從0,1,2,3,4...開始,而關係型數組則非,理解為帶key的(key為鍵) 開始寫一個數組: 當然也可以這樣寫: 現在來遍歷這個數組 ...
  • 異常處理 AttributeError 試圖訪問一個對象沒有的樹形,比如foo.x,但是foo沒有屬性xIOError 輸入/輸出異常;基本上是無法打開文件ImportError 無法引入模塊或包;基本上是路徑問題或名稱錯誤IndentationError 語法錯誤(的子類) ;代碼沒有正確對齊In ...
  • 一個禮拜之後我終於從成都回來了, 從今天開始更新會恢復... 一點小的改進 寫 的時候距離我上一次寫已經一個禮拜了, 所以我回顧了一下之前的代碼, 發現還是有瑕疵. 比如考慮到一個較短的程式, 短到小於BUFFERSIZE(256), 這時其實我的程式是有錯的, 因為此時 中的內容有一部分是未定義的 ...
  • <mirror> <id>sprintio</id> <mirrorOf>central</mirrorOf> <name>Human Readable Name for this Mirror.</name> <url>https://repo.spring.io/libs-snapshot/</ ...
  • --> Java 對TCP協議的支持: --> java.net包中定義了兩個類ServerSocket 和Socket ,分別用來實現雙向連接的server 端和client 端。 --> Client 類定義客戶端 --> ClientSend 類 定義客戶端向服務端發送信息的線程 --> Cl ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...