From 59ca46db3ce53014f1e176ddbc744bfa10da917a Mon Sep 17 00:00:00 2001 From: hanwn <30523763+Hanwn@users.noreply.github.com> Date: Tue, 11 Apr 2023 10:25:47 +0800 Subject: [PATCH] fix: `limit(0).offset(0)` return all data (#6191) Co-authored-by: hanwang --- clause/limit.go | 2 +- clause/limit_test.go | 4 ++++ 2 files changed, 5 insertions(+), 1 deletion(-) diff --git a/clause/limit.go b/clause/limit.go index 3ede7385c..abda00551 100644 --- a/clause/limit.go +++ b/clause/limit.go @@ -33,7 +33,7 @@ func (limit Limit) MergeClause(clause *Clause) { clause.Name = "" if v, ok := clause.Expression.(Limit); ok { - if (limit.Limit == nil || *limit.Limit == 0) && (v.Limit != nil && *v.Limit != 0) { + if (limit.Limit == nil || *limit.Limit == 0) && v.Limit != nil { limit.Limit = v.Limit } diff --git a/clause/limit_test.go b/clause/limit_test.go index 79065ab67..a9fd4e24a 100644 --- a/clause/limit_test.go +++ b/clause/limit_test.go @@ -28,6 +28,10 @@ func TestLimit(t *testing.T) { []clause.Interface{clause.Select{}, clause.From{}, clause.Limit{Limit: &limit0}}, "SELECT * FROM `users` LIMIT 0", nil, }, + { + []clause.Interface{clause.Select{}, clause.From{}, clause.Limit{Limit: &limit0}, clause.Limit{Offset: 0}}, + "SELECT * FROM `users` LIMIT 0", nil, + }, { []clause.Interface{clause.Select{}, clause.From{}, clause.Limit{Offset: 20}}, "SELECT * FROM `users` OFFSET 20", nil,