我剛剛在 StackOverflow 上提的問題,求解答。
http://stackoverflow.com/ques...
一個 Package 模型,有許多 Step 模型。 Step 的字段中有這樣兩條,tinyint 型 status 字段和 時間戳字段。
假設一個 Package A,有下列 steps
18號10點,status 為 1
19號9點,status 為 2
假設一個 Package B,有下列 steps
19號8點,status 為 1
19號9點,status 為 2
19號10點,status 為 3
這樣 A 的最新 step status 是 2,B 是 3.
然後,如何查詢最新 step status 為 2 的 packages?
我嘗試在 package 模型中加入
<code>public function steps() { return $this->hasMany('App\Step'); } public function status() { return $this->steps()->latest()->limit(1); } </code>
然後這樣查詢
<code>Package::whereHas('status', function ($q) { $q->where('status', 2); })->get(); </code>
但是卻不能得到期望的結果。
所謂不是期望的結果,指的是,如果,packages 表裡面,只有B 這一個,我想查詢出最新step status 為2 的packages,B 最新是3 所以應該結果為空,但這樣查詢出結果並不是空,而是包含了B。
然後我試著換成
<code>public function status() { return $this->hasOne('App\Step')->latest(); } </code>
也還是一樣。
剛學 Laravel ,遇到這個問題很困惑,也查了很多 Google ,都沒有想要的答案。希望大家幫幫我,多謝!
用的 Laravel 5.3
回覆內容:
我剛剛在 StackOverflow 上提的問題,求解答。
http://stackoverflow.com/ques...
一個 Package 模型,有許多 Step 模型。 Step 的字段中有這樣兩條,tinyint 型 status 字段和 時間戳字段。
假設一個 Package A,有下列 steps
18號10點,status 為 1
19號9點,status 為 2
假設一個 Package B,有下列 steps
19號8點,status 為 1
19號9點,status 為 2
19號10點,status 為 3
這樣 A 的最新 step status 是 2,B 是 3.
然後,如何查詢最新 step status 為 2 的 packages?
我嘗試在 package 模型中加入
<code>public function steps() { return $this->hasMany('App\Step'); } public function status() { return $this->steps()->latest()->limit(1); } </code>
然後這樣查詢
<code>Package::whereHas('status', function ($q) { $q->where('status', 2); })->get(); </code>
但是卻不能得到期望的結果。
所謂不是期望的結果,指的是,如果,packages 表裡面,只有B 這一個,我想查詢出最新step status 為2 的packages,B 最新是3 所以應該結果為空,但這樣查詢出結果並不是空,而是包含了B。
然後我試著換成
<code>public function status() { return $this->hasOne('App\Step')->latest(); } </code>
也還是一樣。
剛學 Laravel ,遇到這個問題很困惑,也查了很多 Google ,都沒有想要的答案。希望大家幫幫我,多謝!
用的 Laravel 5.3
<code>Package::whereHas('steps', function ($q) { $q->where('status', 2); })->get();</code>

負載均衡會影響會話管理,但可以通過會話複製、會話粘性和集中式會話存儲解決。 1.會話複製在服務器間複製會話數據。 2.會話粘性將用戶請求定向到同一服務器。 3.集中式會話存儲使用獨立服務器如Redis存儲會話數據,確保數據共享。

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

PHP會話的替代方案包括Cookies、Token-basedAuthentication、Database-basedSessions和Redis/Memcached。 1.Cookies通過在客戶端存儲數據來管理會話,簡單但安全性低。 2.Token-basedAuthentication使用令牌驗證用戶,安全性高但需額外邏輯。 3.Database-basedSessions將數據存儲在數據庫中,擴展性好但可能影響性能。 4.Redis/Memcached使用分佈式緩存提高性能和擴展性,但需額外配

Sessionhijacking是指攻擊者通過獲取用戶的sessionID來冒充用戶。防範方法包括:1)使用HTTPS加密通信;2)驗證sessionID的來源;3)使用安全的sessionID生成算法;4)定期更新sessionID。

本文比較了PHP和ASP.NET,重點是它們對大規模Web應用程序,性能差異和安全功能的適用性。兩者對於大型項目都是可行的,但是PHP是開源和無關的,而ASP.NET,


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver CS6
視覺化網頁開發工具

WebStorm Mac版
好用的JavaScript開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。