Files
mayfly-go/server/internal/db/application/meta.go

29 lines
1.1 KiB
Go
Raw Normal View History

2022-10-15 17:38:34 +08:00
package application
2022-10-16 14:22:19 +08:00
// -----------------------------------元数据接口定义------------------------------------------
2022-10-15 17:38:34 +08:00
// 数据库元信息接口(表、列等元信息)
2022-10-16 14:22:19 +08:00
// 所有数据查出来直接用map接收注意不同数据库实现该接口返回的map中的key需要统一.
// 即: 使用别名统一即可。如table_name AS tableName
2022-10-15 17:38:34 +08:00
type DbMetadata interface {
2022-10-16 14:22:19 +08:00
2022-10-15 17:38:34 +08:00
// 获取表基础元信息
// 表名: tableName, 备注: tableComment
GetTables() []map[string]interface{}
// 获取指定表名的所有列元信息
// 表名: tableName, 列名: columnName, 列类型: columnType, 备注: columnComment, 是否可为null: nullable, 其他信息: extra
GetColumns(tableNames ...string) []map[string]interface{}
// 获取表主键字段名,目前默认第一个字段
GetPrimaryKey(tablename string) string
// 获取表信息比GetTables获取更详细的表信息
GetTableInfos() []map[string]interface{}
// 获取表索引信息
GetTableIndex(tableName string) []map[string]interface{}
// 获取建表ddl
GetCreateTableDdl(tableName string) []map[string]interface{}
}