api2sql基础的能力 #8
@ -31,5 +31,7 @@ type IWrapperDatabaseClient interface {
 | 
				
			|||||||
	// CacheDataTableStructureConfig 缓存数据表结构的配置
 | 
						// CacheDataTableStructureConfig 缓存数据表结构的配置
 | 
				
			||||||
	CacheDataTableStructureConfig() *define.CacheTableStructureConfig
 | 
						CacheDataTableStructureConfig() *define.CacheTableStructureConfig
 | 
				
			||||||
	// GetTableFieldList 获取指定表数据字段列表
 | 
						// GetTableFieldList 获取指定表数据字段列表
 | 
				
			||||||
	GetTableFieldList(tableName string) ([]*define.ColumnInfo, error)
 | 
						GetTableFieldList(tableName string) ([]*define.ColumnConfig, error)
 | 
				
			||||||
 | 
						// SetTableStructure 设置数据表结构
 | 
				
			||||||
 | 
						SetTableStructure(tableConfigTable map[string][]*define.ColumnConfig)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -70,14 +70,3 @@ type SqlCondition struct {
 | 
				
			|||||||
	Operate string `json:"operate"` // 操作 : == / !== / in / not in / like / not like
 | 
						Operate string `json:"operate"` // 操作 : == / !== / in / not in / like / not like
 | 
				
			||||||
	Value   any    `json:"value"`   // 数据值
 | 
						Value   any    `json:"value"`   // 数据值
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
// ColumnConfig ...
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// Author : go_developer@163.com<白茶清欢>
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// Date : 16:42 2024/8/23
 | 
					 | 
				
			||||||
type ColumnConfig struct {
 | 
					 | 
				
			||||||
	Column string `json:"column"` // 字段名
 | 
					 | 
				
			||||||
	Alias  string `json:"alias"`  // 字段别名
 | 
					 | 
				
			||||||
	Type   string `json:"type"`   // 字段类型
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -16,3 +16,14 @@ type CacheTableStructureConfig struct {
 | 
				
			|||||||
	Enable           bool `json:"enable"`             // 是否启用表结构缓存
 | 
						Enable           bool `json:"enable"`             // 是否启用表结构缓存
 | 
				
			||||||
	SyncTimeInterval int  `json:"sync_time_interval"` // 开启的情况向, 多久同步一次表结构, 默认值 3600, 单位 : s
 | 
						SyncTimeInterval int  `json:"sync_time_interval"` // 开启的情况向, 多久同步一次表结构, 默认值 3600, 单位 : s
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// ColumnConfig ...
 | 
				
			||||||
 | 
					//
 | 
				
			||||||
 | 
					// Author : go_developer@163.com<白茶清欢>
 | 
				
			||||||
 | 
					//
 | 
				
			||||||
 | 
					// Date : 16:42 2024/8/23
 | 
				
			||||||
 | 
					type ColumnConfig struct {
 | 
				
			||||||
 | 
						Column string `json:"column"` // 字段名
 | 
				
			||||||
 | 
						Alias  string `json:"alias"`  // 字段别名
 | 
				
			||||||
 | 
						Type   string `json:"type"`   // 字段类型
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -19,6 +19,7 @@ import (
 | 
				
			|||||||
	"gorm.io/driver/sqlite"
 | 
						"gorm.io/driver/sqlite"
 | 
				
			||||||
	"gorm.io/gorm"
 | 
						"gorm.io/gorm"
 | 
				
			||||||
	gormLogger "gorm.io/gorm/logger"
 | 
						gormLogger "gorm.io/gorm/logger"
 | 
				
			||||||
 | 
						"strings"
 | 
				
			||||||
	"sync"
 | 
						"sync"
 | 
				
			||||||
	"time"
 | 
						"time"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
@ -37,7 +38,7 @@ type DBClient struct {
 | 
				
			|||||||
	Cfg                       define.Driver                     // 数据库配置
 | 
						Cfg                       define.Driver                     // 数据库配置
 | 
				
			||||||
	cacheTableStructureConfig *define.CacheTableStructureConfig // 缓存配置
 | 
						cacheTableStructureConfig *define.CacheTableStructureConfig // 缓存配置
 | 
				
			||||||
	lock                      *sync.RWMutex                     // 操作锁
 | 
						lock                      *sync.RWMutex                     // 操作锁
 | 
				
			||||||
	tableStructureCache       map[string][]*define.ColumnInfo   // 表结构缓存
 | 
						tableStructureCache       map[string][]*define.ColumnConfig // 表结构缓存
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
// Init 初始化客户端
 | 
					// Init 初始化客户端
 | 
				
			||||||
@ -179,10 +180,10 @@ func (dc *DBClient) CacheDataTableStructureConfig() *define.CacheTableStructureC
 | 
				
			|||||||
// Author : go_developer@163.com<白茶清欢>
 | 
					// Author : go_developer@163.com<白茶清欢>
 | 
				
			||||||
//
 | 
					//
 | 
				
			||||||
// Date : 15:07 2024/8/21
 | 
					// Date : 15:07 2024/8/21
 | 
				
			||||||
func (dc *DBClient) GetTableFieldList(tableName string) ([]*define.ColumnInfo, error) {
 | 
					func (dc *DBClient) GetTableFieldList(tableName string) ([]*define.ColumnConfig, error) {
 | 
				
			||||||
	if !dc.CacheDataTableStructureConfig().Enable {
 | 
						if !dc.CacheDataTableStructureConfig().Enable {
 | 
				
			||||||
		// 未启用缓存, 返回空list
 | 
							// 未启用缓存, 返回空list
 | 
				
			||||||
		return make([]*define.ColumnInfo, 0), nil
 | 
							return make([]*define.ColumnConfig, 0), nil
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	dc.lock.RLock()
 | 
						dc.lock.RLock()
 | 
				
			||||||
	defer dc.lock.RUnlock()
 | 
						defer dc.lock.RUnlock()
 | 
				
			||||||
@ -198,6 +199,10 @@ func (dc *DBClient) GetTableFieldList(tableName string) ([]*define.ColumnInfo, e
 | 
				
			|||||||
//
 | 
					//
 | 
				
			||||||
// Date : 15:17 2024/8/21
 | 
					// Date : 15:17 2024/8/21
 | 
				
			||||||
func (dc *DBClient) syncDbTableStructure(ignoreErr bool) error {
 | 
					func (dc *DBClient) syncDbTableStructure(ignoreErr bool) error {
 | 
				
			||||||
 | 
						if !dc.CacheDataTableStructureConfig().Enable {
 | 
				
			||||||
 | 
							// 自动同步不可用
 | 
				
			||||||
 | 
							return nil
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
	var (
 | 
						var (
 | 
				
			||||||
		err       error
 | 
							err       error
 | 
				
			||||||
		tableList []string
 | 
							tableList []string
 | 
				
			||||||
@ -208,7 +213,7 @@ func (dc *DBClient) syncDbTableStructure(ignoreErr bool) error {
 | 
				
			|||||||
	if tableList, err = systemDao.GetTableList(c); nil != err {
 | 
						if tableList, err = systemDao.GetTableList(c); nil != err {
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	tableStructCache := make(map[string][]*define.ColumnInfo)
 | 
						tableStructCache := make(map[string][]*define.ColumnConfig)
 | 
				
			||||||
	for _, itemTableName := range tableList {
 | 
						for _, itemTableName := range tableList {
 | 
				
			||||||
		fieldList, loadTableErr := systemDao.GetTableInfo(c, dc.Cfg.Database, itemTableName)
 | 
							fieldList, loadTableErr := systemDao.GetTableInfo(c, dc.Cfg.Database, itemTableName)
 | 
				
			||||||
		if nil != loadTableErr {
 | 
							if nil != loadTableErr {
 | 
				
			||||||
@ -217,7 +222,22 @@ func (dc *DBClient) syncDbTableStructure(ignoreErr bool) error {
 | 
				
			|||||||
			}
 | 
								}
 | 
				
			||||||
			return loadTableErr
 | 
								return loadTableErr
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		tableStructCache[itemTableName] = fieldList
 | 
							tableStructCache[itemTableName] = make([]*define.ColumnConfig, 0)
 | 
				
			||||||
 | 
							for _, itemColumn := range fieldList {
 | 
				
			||||||
 | 
								fieldType := "string"
 | 
				
			||||||
 | 
								if strings.Contains(itemColumn.ColumnType, "int") {
 | 
				
			||||||
 | 
									if strings.Contains(itemColumn.ColumnType, "unsigned") {
 | 
				
			||||||
 | 
										fieldType = "uint"
 | 
				
			||||||
 | 
									} else {
 | 
				
			||||||
 | 
										fieldType = "int"
 | 
				
			||||||
 | 
									}
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
								tableStructCache[itemTableName] = append(tableStructCache[itemTableName], &define.ColumnConfig{
 | 
				
			||||||
 | 
									Column: itemColumn.ColumnName,
 | 
				
			||||||
 | 
									Alias:  itemColumn.ColumnName,
 | 
				
			||||||
 | 
									Type:   fieldType,
 | 
				
			||||||
 | 
								})
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	// 更新缓存结果
 | 
						// 更新缓存结果
 | 
				
			||||||
	dc.lock.Lock()
 | 
						dc.lock.Lock()
 | 
				
			||||||
@ -225,3 +245,20 @@ func (dc *DBClient) syncDbTableStructure(ignoreErr bool) error {
 | 
				
			|||||||
	dc.tableStructureCache = tableStructCache
 | 
						dc.tableStructureCache = tableStructCache
 | 
				
			||||||
	return nil
 | 
						return nil
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// SetTableStructure 设置表结构, 一旦调用人工设置, 则将终止自动同步
 | 
				
			||||||
 | 
					//
 | 
				
			||||||
 | 
					// Author : go_developer@163.com<白茶清欢>
 | 
				
			||||||
 | 
					//
 | 
				
			||||||
 | 
					// Date : 17:06 2024/8/23
 | 
				
			||||||
 | 
					func (dc *DBClient) SetTableStructure(tableConfigTable map[string][]*define.ColumnConfig) {
 | 
				
			||||||
 | 
						if nil != dc.cacheTableStructureConfig {
 | 
				
			||||||
 | 
							// 关闭自动同步
 | 
				
			||||||
 | 
							dc.cacheTableStructureConfig.Enable = false
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						dc.lock.Lock()
 | 
				
			||||||
 | 
						for table, columnConfig := range tableConfigTable {
 | 
				
			||||||
 | 
							dc.tableStructureCache[table] = columnConfig
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						dc.lock.Unlock()
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user