Compare commits
No commits in common. "main" and "v1.0.1022" have entirely different histories.
|
|
@ -48,7 +48,7 @@ var pageInfo = []string{
|
||||||
}
|
}
|
||||||
|
|
||||||
// Crud -------------------------- 泛型CURD核心结构体 --------------------------
|
// Crud -------------------------- 泛型CURD核心结构体 --------------------------
|
||||||
// Crud GORM 版本的泛型CURD封装,R为对应的模型结构体, C为对应模型结构体的字段结构体
|
// Crud GORM 版本的泛型CURD封装,R为对应的模型结构体
|
||||||
type Crud[R any, C any] struct {
|
type Crud[R any, C any] struct {
|
||||||
Dao IDao[C]
|
Dao IDao[C]
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -98,7 +98,7 @@ func TestBuildWhere(t *testing.T) {
|
||||||
// TestBuildMap 测试 BuildMap 方法
|
// TestBuildMap 测试 BuildMap 方法
|
||||||
func TestBuildMap(t *testing.T) {
|
func TestBuildMap(t *testing.T) {
|
||||||
// 创建一个空的 Crud 实例用于测试(不需要实际的 Dao)
|
// 创建一个空的 Crud 实例用于测试(不需要实际的 Dao)
|
||||||
var crud Crud[interface{}, interface{}]
|
var crud Crud[interface{}]
|
||||||
|
|
||||||
t.Run("BuildMapWithoutField", func(t *testing.T) {
|
t.Run("BuildMapWithoutField", func(t *testing.T) {
|
||||||
result := crud.BuildMap(">", 18)
|
result := crud.BuildMap(">", 18)
|
||||||
|
|
@ -131,7 +131,7 @@ func TestBuildMap(t *testing.T) {
|
||||||
|
|
||||||
// TestClearField 测试 ClearField 方法
|
// TestClearField 测试 ClearField 方法
|
||||||
func TestClearField(t *testing.T) {
|
func TestClearField(t *testing.T) {
|
||||||
var crud Crud[interface{}, interface{}]
|
var crud Crud[interface{}]
|
||||||
|
|
||||||
t.Run("ClearFieldBasic", func(t *testing.T) {
|
t.Run("ClearFieldBasic", func(t *testing.T) {
|
||||||
req := struct {
|
req := struct {
|
||||||
|
|
@ -210,7 +210,7 @@ func TestClearField(t *testing.T) {
|
||||||
|
|
||||||
// TestBuildWhereAndOr 测试 BuildWhereAndOr 方法
|
// TestBuildWhereAndOr 测试 BuildWhereAndOr 方法
|
||||||
func TestBuildWhereAndOr(t *testing.T) {
|
func TestBuildWhereAndOr(t *testing.T) {
|
||||||
var crud Crud[interface{}, interface{}]
|
var crud Crud[interface{}]
|
||||||
|
|
||||||
t.Run("SimpleAND", func(t *testing.T) {
|
t.Run("SimpleAND", func(t *testing.T) {
|
||||||
where := crud.BuildWhereAndOr().
|
where := crud.BuildWhereAndOr().
|
||||||
|
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
||||||
package base
|
|
||||||
|
|
||||||
import (
|
|
||||||
"github.com/gogf/gf/v2/os/gtime"
|
|
||||||
"gorm.io/gorm"
|
|
||||||
)
|
|
||||||
|
|
||||||
type IdModel struct {
|
|
||||||
Id int `json:"id" gorm:"column:id;type:int(11);common:id"`
|
|
||||||
}
|
|
||||||
type TimeModel struct {
|
|
||||||
CreateTime string `json:"create_time" gorm:"column:create_time;type:varchar(255);common:创建时间"`
|
|
||||||
UpdateTime string `json:"update_time" gorm:"column:update_time;type:varchar(255);common:更新时间"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (tm *TimeModel) BeforeCreate(scope *gorm.DB) error {
|
|
||||||
scope.Set("create_time", gtime.Datetime())
|
|
||||||
scope.Set("update_time", gtime.Datetime())
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (tm *TimeModel) BeforeUpdate(scope *gorm.DB) error {
|
|
||||||
scope.Set("update_time", gtime.Datetime())
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
//func (tm *TimeModel) AfterFind(scope *gorm.DB) error {
|
|
||||||
// tm.CreateTime = gtime.New(tm.CreateTime).String()
|
|
||||||
// tm.UpdateTime = gtime.New(tm.UpdateTime).String()
|
|
||||||
// return nil
|
|
||||||
//}
|
|
||||||
|
|
@ -3,7 +3,6 @@ package database
|
||||||
import (
|
import (
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"fmt"
|
"fmt"
|
||||||
"time"
|
|
||||||
|
|
||||||
"git.magicany.cc/black1552/gin-base/config"
|
"git.magicany.cc/black1552/gin-base/config"
|
||||||
"git.magicany.cc/black1552/gin-base/log"
|
"git.magicany.cc/black1552/gin-base/log"
|
||||||
|
|
@ -41,9 +40,6 @@ func init() {
|
||||||
// 构建 GORM 配置
|
// 构建 GORM 配置
|
||||||
gormConfig := &gorm.Config{
|
gormConfig := &gorm.Config{
|
||||||
SkipDefaultTransaction: true,
|
SkipDefaultTransaction: true,
|
||||||
NowFunc: func() time.Time {
|
|
||||||
return time.Now().Local()
|
|
||||||
},
|
|
||||||
// 命名策略:保持与模型一致,避免字段/表名转换问题
|
// 命名策略:保持与模型一致,避免字段/表名转换问题
|
||||||
NamingStrategy: schema.NamingStrategy{
|
NamingStrategy: schema.NamingStrategy{
|
||||||
SingularTable: true, // 表名禁用复数形式(例如 User 对应 user 表,而非 users)
|
SingularTable: true, // 表名禁用复数形式(例如 User 对应 user 表,而非 users)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue