-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.go
66 lines (56 loc) · 1.72 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package main
import (
"fmt"
"github.com/manuelarte/pagorminator"
"gorm.io/driver/sqlite"
"gorm.io/gorm"
"strconv"
)
type Product struct {
gorm.Model
Code string
Price Price
}
type Price struct {
gorm.Model
Unit uint
Currency string
ProductID uint
}
func (p Product) String() string {
return fmt.Sprintf("Product{Code: %s, Price: %d}", p.Code, p.Price)
}
func main() {
db, err := gorm.Open(sqlite.Open("file:mem?mode=memory&cache=shared"), &gorm.Config{})
if err != nil {
panic("failed to connect database")
}
_ = db.Use(pagorminator.PaGormMinator{})
_ = db.AutoMigrate(&Product{}, &Price{})
length := 10
for i := 0; i < length; i++ {
errCreatingProduct := db.Create(&Product{Code: strconv.Itoa(i), Price: Price{Unit: uint(i), Currency: "EUR"}})
if errCreatingProduct.Error != nil {
panic(errCreatingProduct.Error)
}
}
fmt.Printf("%d product created\n", length)
var products []*Product
pageRequest, _ := pagorminator.PageRequest(0, 5)
txErr := db.Debug().Clauses(pageRequest).Preload("Price").Find(&products).Error
if txErr != nil {
panic(txErr)
}
fmt.Printf("PageRequest result:(Page: %d, Size: %d, TotalElements: %d, TotalPages: %d)\n",
pageRequest.GetPage(), pageRequest.GetSize(), pageRequest.GetTotalElements(), pageRequest.GetTotalPages())
for _, product := range products {
fmt.Printf("\t Product: %s\n", product)
}
pageRequest, _ = pagorminator.PageRequest(1, 5)
db.Clauses(pageRequest).Find(&products)
fmt.Printf("PageRequest result:(Page: %d, Size: %d, TotalElements: %d, TotalPages: %d)\n",
pageRequest.GetPage(), pageRequest.GetSize(), pageRequest.GetTotalElements(), pageRequest.GetTotalPages())
for _, product := range products {
fmt.Printf("\t Product: %s\n", product)
}
}