66 Star 448 Fork 79

GVPspringrain / zorm

加入 Gitee
与超过 800 万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
IEntity.go 6.56 KB
一键复制 编辑 原始数据 按行查看 历史
springrain 提交于 2021-03-02 09:40 . 修改注释
package zorm
//IEntityStruct "struct"实体类的接口,所有的struct实体类都要实现这个接口
//IEntityStruct The interface of the "struct" entity class, all struct entity classes must implement this interface
type IEntityStruct interface {
//获取表名称
//Get the table name.
GetTableName() string
//获取数据库表的主键字段名称.因为要兼容Map,只能是数据库的字段名称
//Get the primary key field name of the database table. Because it is compatible with Map, it can only be the field name of the database
GetPKColumnName() string
//GetPkSequence 主键序列,因为需要兼容多种数据库的序列,所以使用map
//key是DBType,value是序列的值,例如oracle的TESTSEQ.NEXTVAL,如果有值,优先级最高
//如果key对应的value是 "",则代表是触发器触发的序列,兼容自增关键字,例如 ["oracle"]""
//GetPkSequence Primary key sequence, because it needs to be compatible with multiple database sequences, map is used
//The key is the DB Type, and the value is the value of the sequence,
//such as Oracle's TESTSEQ.NEXTVAL. If there is a value, the priority is the highest
//If the value corresponding to the key is "", it means the sequence triggered by the trigger
//Compatible with auto-increment keywords, such as ["oracle"]""
GetPkSequence() map[string]string
}
//IEntityMap 使用Map保存数据,用于不方便使用struct的场景,如果主键是自增或者序列,不要"entityMap.Set"主键的值
//IEntityMap Use Map to save data for scenarios where it is not convenient to use struct
//If the primary key is auto-increment or sequence, do not "entity Map.Set" the value of the primary key
type IEntityMap interface {
//获取表名称
//Get the table name
GetTableName() string
//获取数据库表的主键字段名称.因为要兼容Map,只能是数据库的字段名称.
//Get the primary key field name of the database table. Because it is compatible with Map, it can only be the field name of the database.
GetPKColumnName() string
//GetPkSequence 主键序列,因为需要兼容多种数据库的序列,所以使用map
//key是DBType,value是序列的值,例如oracle的TESTSEQ.NEXTVAL,如果有值,优先级最高
//如果key对应的value是 "",则代表是触发器触发的序列,兼容自增关键字,例如 ["oracle"]""
//GetPkSequence Primary key sequence, because it needs to be compatible with multiple database sequences, map is used
//The key is the DB Type, and the value is the value of the sequence,
//such as Oracle's TESTSEQ.NEXTVAL. If there is a value, the priority is the highest
//If the value corresponding to the key is "", it means the sequence triggered by the trigger
//Compatible with auto-increment keywords, such as ["oracle"]""
GetPkSequence() map[string]string
//针对Map类型,记录数据库字段
//For Map type, record database fields.
GetDBFieldMap() map[string]interface{}
//设置数据库字段的值
//Set the value of a database field.
Set(key string, value interface{}) map[string]interface{}
}
//EntityStruct "IBaseEntity" 的基础实现,所有的实体类都匿名注入.这样就类似实现继承了,如果接口增加方法,调整这个默认实现即可
//EntityStruct The basic implementation of "IBaseEntity", all entity classes are injected anonymously
//This is similar to implementation inheritance. If the interface adds methods, adjust the default implementation
type EntityStruct struct {
}
//默认数据库的主键列名
//Primary key column name of the default database
const defaultPkName = "id"
//获取表名称
/*
func (entity *EntityStruct) GetTableName() string {
return ""
}
*/
//GetPKColumnName 获取数据库表的主键字段名称.因为要兼容Map,只能是数据库的字段名称
//GetPKColumnName Get the primary key field name of the database table
//Because it is compatible with Map, it can only be the field name of the database
func (entity *EntityStruct) GetPKColumnName() string {
return defaultPkName
}
//var defaultPkSequence = make(map[string]string, 0)
//GetPkSequence 主键序列,需要兼容多种数据库的序列,使用map,key是DBType,value是序列的值,例如oracle的TESTSEQ.NEXTVAL,如果有值,优先级最高
//如果key对应的value是 "",则代表是触发器触发的序列,兼容自增关键字,例如 ["oracle"]""
func (entity *EntityStruct) GetPkSequence() map[string]string {
return nil
}
//-------------------------------------------------------------------------//
//EntityMap IEntityMap的基础实现,可以直接使用或者匿名注入
type EntityMap struct {
//表名
tableName string
//主键列名
PkColumnName string
//主键序列,需要兼容多种数据库的序列,使用map,key是DBType,value是序列的值,例如oracle的TESTSEQ.NEXTVAL,如果有值,优先级最高
PkSequence map[string]string
//数据库字段,不暴露外部
dbFieldMap map[string]interface{}
}
//NewEntityMap 初始化Map,必须传入表名称
func NewEntityMap(tbName string) *EntityMap {
entityMap := EntityMap{}
entityMap.dbFieldMap = map[string]interface{}{}
entityMap.tableName = tbName
entityMap.PkColumnName = defaultPkName
return &entityMap
}
//GetTableName 获取表名称
func (entity *EntityMap) GetTableName() string {
return entity.tableName
}
//GetPKColumnName 获取数据库表的主键字段名称.因为要兼容Map,只能是数据库的字段名称
func (entity *EntityMap) GetPKColumnName() string {
return entity.PkColumnName
}
//GetPkSequence 主键序列,因为需要兼容多种数据库的序列,所以使用map
//key是DBType,value是序列的值,例如oracle的TESTSEQ.NEXTVAL,如果有值,优先级最高
//如果key对应的value是 "",则代表是触发器触发的序列,兼容自增关键字,例如 ["oracle"]""
//GetPkSequence Primary key sequence, because it needs to be compatible with multiple database sequences, map is used
//The key is the DB Type, and the value is the value of the sequence,
//such as Oracle's TESTSEQ.NEXTVAL. If there is a value, the priority is the highest
//If the value corresponding to the key is "", it means the sequence triggered by the trigger
//Compatible with auto-increment keywords, such as ["oracle"]""
func (entity *EntityMap) GetPkSequence() map[string]string {
return entity.PkSequence
}
//GetDBFieldMap 针对Map类型,记录数据库字段
//GetDBFieldMap For Map type, record database fields
func (entity *EntityMap) GetDBFieldMap() map[string]interface{} {
return entity.dbFieldMap
}
//Set 设置数据库字段
//Set Set database fields
func (entity *EntityMap) Set(key string, value interface{}) map[string]interface{} {
entity.dbFieldMap[key] = value
return entity.dbFieldMap
}
Go
1
https://gitee.com/chunanyong/zorm.git
git@gitee.com:chunanyong/zorm.git
chunanyong
zorm
zorm
v1.5.9

搜索帮助