mirror of
https://github.com/casdoor/casdoor.git
synced 2025-05-23 10:45:47 +08:00
Speed up user pagination query
This commit is contained in:
parent
5349fa7ff3
commit
b1b3184e75
@ -280,3 +280,44 @@ func GetSession(owner string, offset, limit int, field, value, sortField, sortOr
|
|||||||
}
|
}
|
||||||
return session
|
return session
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func GetSessionForUser(owner string, offset, limit int, field, value, sortField, sortOrder string) *xorm.Session {
|
||||||
|
session := adapter.Engine.Prepare()
|
||||||
|
if offset != -1 && limit != -1 {
|
||||||
|
session.Limit(limit, offset)
|
||||||
|
}
|
||||||
|
if owner != "" {
|
||||||
|
session = session.And("owner=?", owner)
|
||||||
|
}
|
||||||
|
if field != "" && value != "" {
|
||||||
|
if filterField(field) {
|
||||||
|
session = session.And(fmt.Sprintf("%s like ?", util.SnakeString(field)), fmt.Sprintf("%%%s%%", value))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if sortField == "" || sortOrder == "" {
|
||||||
|
sortField = "created_time"
|
||||||
|
}
|
||||||
|
|
||||||
|
tableName := "user"
|
||||||
|
if offset == -1 {
|
||||||
|
if sortOrder == "ascend" {
|
||||||
|
session = session.Asc(util.SnakeString(sortField))
|
||||||
|
} else {
|
||||||
|
session = session.Desc(util.SnakeString(sortField))
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if sortOrder == "ascend" {
|
||||||
|
session = session.Alias("a").
|
||||||
|
Join("INNER", []string{tableName, "b"}, "a.owner = b.owner and a.name = b.name").
|
||||||
|
Select("b.*").
|
||||||
|
Asc("a." + util.SnakeString(sortField))
|
||||||
|
} else {
|
||||||
|
session = session.Alias("a").
|
||||||
|
Join("INNER", []string{tableName, "b"}, "a.owner = b.owner and a.name = b.name").
|
||||||
|
Select("b.*").
|
||||||
|
Desc("a." + util.SnakeString(sortField))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return session
|
||||||
|
}
|
||||||
|
@ -24,7 +24,8 @@ type Migrator_1_314_0_PR_1841 struct{}
|
|||||||
func (*Migrator_1_314_0_PR_1841) IsMigrationNeeded() bool {
|
func (*Migrator_1_314_0_PR_1841) IsMigrationNeeded() bool {
|
||||||
count, err := adapter.Engine.Where("password_type=?", "").Count(&User{})
|
count, err := adapter.Engine.Where("password_type=?", "").Count(&User{})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
// table doesn't exist
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
return count > 100
|
return count > 100
|
||||||
|
@ -34,7 +34,7 @@ const (
|
|||||||
type User struct {
|
type User struct {
|
||||||
Owner string `xorm:"varchar(100) notnull pk" json:"owner"`
|
Owner string `xorm:"varchar(100) notnull pk" json:"owner"`
|
||||||
Name string `xorm:"varchar(100) notnull pk" json:"name"`
|
Name string `xorm:"varchar(100) notnull pk" json:"name"`
|
||||||
CreatedTime string `xorm:"varchar(100)" json:"createdTime"`
|
CreatedTime string `xorm:"varchar(100) index" json:"createdTime"`
|
||||||
UpdatedTime string `xorm:"varchar(100)" json:"updatedTime"`
|
UpdatedTime string `xorm:"varchar(100)" json:"updatedTime"`
|
||||||
|
|
||||||
Id string `xorm:"varchar(100) index" json:"id"`
|
Id string `xorm:"varchar(100) index" json:"id"`
|
||||||
@ -208,7 +208,7 @@ func GetGlobalUsers() ([]*User, error) {
|
|||||||
|
|
||||||
func GetPaginationGlobalUsers(offset, limit int, field, value, sortField, sortOrder string) ([]*User, error) {
|
func GetPaginationGlobalUsers(offset, limit int, field, value, sortField, sortOrder string) ([]*User, error) {
|
||||||
users := []*User{}
|
users := []*User{}
|
||||||
session := GetSession("", offset, limit, field, value, sortField, sortOrder)
|
session := GetSessionForUser("", offset, limit, field, value, sortField, sortOrder)
|
||||||
err := session.Find(&users)
|
err := session.Find(&users)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -258,7 +258,7 @@ func GetSortedUsers(owner string, sorter string, limit int) ([]*User, error) {
|
|||||||
|
|
||||||
func GetPaginationUsers(owner string, offset, limit int, field, value, sortField, sortOrder string) ([]*User, error) {
|
func GetPaginationUsers(owner string, offset, limit int, field, value, sortField, sortOrder string) ([]*User, error) {
|
||||||
users := []*User{}
|
users := []*User{}
|
||||||
session := GetSession(owner, offset, limit, field, value, sortField, sortOrder)
|
session := GetSessionForUser(owner, offset, limit, field, value, sortField, sortOrder)
|
||||||
err := session.Find(&users)
|
err := session.Find(&users)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
Loading…
x
Reference in New Issue
Block a user