cutego/modules/core/dao/config_dao.go

173 lines
4.6 KiB
Go
Raw Normal View History

2022-03-01 13:50:13 +08:00
package dao
import (
2023-01-18 15:40:27 +08:00
"cutego/modules/core/api/v1/request"
2023-01-18 17:21:12 +08:00
"cutego/modules/core/dataobject"
2023-01-18 18:02:58 +08:00
"cutego/pkg/cache"
2023-01-18 17:09:49 +08:00
"cutego/pkg/constant"
2023-01-18 17:46:25 +08:00
"cutego/pkg/logging"
2022-03-01 13:50:13 +08:00
"cutego/pkg/page"
2023-01-18 17:09:49 +08:00
"cutego/refs"
2022-03-01 13:50:13 +08:00
"github.com/druidcaesa/gotool"
"github.com/go-xorm/xorm"
)
type ConfigDao struct {
}
func (d ConfigDao) sql(session *xorm.Session) *xorm.Session {
return session.Table("sys_config")
}
// SelectByConfigKey 根据键名查询参数配置信息
2023-01-18 17:21:12 +08:00
func (d ConfigDao) SelectByConfigKey(configKey string) *dataobject.SysConfig {
config := dataobject.SysConfig{}
2023-01-18 17:09:49 +08:00
_, err := d.sql(refs.SqlDB.NewSession()).Where("config_key = ?", configKey).Get(&config)
2022-03-01 13:50:13 +08:00
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return nil
}
return &config
}
// SelectPage 分页查询数据
2023-01-18 17:21:12 +08:00
func (d ConfigDao) SelectPage(query request.ConfigQuery) (*[]dataobject.SysConfig, int64) {
configs := make([]dataobject.SysConfig, 0)
2023-01-18 17:09:49 +08:00
session := d.sql(refs.SqlDB.NewSession())
2022-03-01 13:50:13 +08:00
if gotool.StrUtils.HasNotEmpty(query.ConfigName) {
session.And("config_name like concat('%', ?, '%')", query.ConfigName)
}
if gotool.StrUtils.HasNotEmpty(query.ConfigType) {
session.And("config_type = ?", query.ConfigType)
}
if gotool.StrUtils.HasNotEmpty(query.ConfigKey) {
session.And("config_key like concat('%', ?, '%')", query.ConfigKey)
}
if gotool.StrUtils.HasNotEmpty(query.BeginTime) {
session.And("date_format(create_time,'%y%m%d') >= date_format(?,'%y%m%d')", query.BeginTime)
}
if gotool.StrUtils.HasNotEmpty(query.EndTime) {
session.And("date_format(create_time,'%y%m%d') <= date_format(?,'%y%m%d')", query.EndTime)
}
total, _ := page.GetTotal(session.Clone())
err := session.Limit(query.PageSize, page.StartSize(query.PageNum, query.PageSize)).Find(&configs)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return nil, 0
}
return &configs, total
}
// CheckConfigKeyUnique 校验是否存在
2023-01-18 17:21:12 +08:00
func (d ConfigDao) CheckConfigKeyUnique(config dataobject.SysConfig) int64 {
2023-01-18 17:09:49 +08:00
session := d.sql(refs.SqlDB.NewSession())
2022-03-01 13:50:13 +08:00
if config.ConfigId > 0 {
session.Where("config_id != ?", config.ConfigId)
}
count, err := session.And("config_key = ?", config.ConfigKey).Cols("config_id").Count()
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return 0
}
return count
}
// Insert 添加数据
2023-01-18 17:21:12 +08:00
func (d ConfigDao) Insert(config dataobject.SysConfig) int64 {
2023-01-18 17:09:49 +08:00
session := refs.SqlDB.NewSession()
2022-03-01 13:50:13 +08:00
session.Begin()
insert, err := session.Insert(&config)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
session.Rollback()
return 0
}
session.Commit()
return insert
}
// SelectById 查询数据
2023-01-18 17:21:12 +08:00
func (d ConfigDao) SelectById(id int64) *dataobject.SysConfig {
config := dataobject.SysConfig{}
2023-01-18 17:09:49 +08:00
session := d.sql(refs.SqlDB.NewSession())
2022-03-01 13:50:13 +08:00
_, err := session.Where("config_id = ?", id).Get(&config)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return nil
}
return &config
}
// Update 修改数据
2023-01-18 17:21:12 +08:00
func (d ConfigDao) Update(config dataobject.SysConfig) int64 {
2023-01-18 17:09:49 +08:00
session := refs.SqlDB.NewSession()
2022-03-01 13:50:13 +08:00
session.Begin()
update, err := session.Where("config_id = ?", config.ConfigId).Update(&config)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
session.Rollback()
return 0
}
session.Commit()
return update
}
// CheckConfigByIds 根据id集合查询
2023-01-18 17:21:12 +08:00
func (d ConfigDao) CheckConfigByIds(list []int64) *[]dataobject.SysConfig {
configs := make([]dataobject.SysConfig, 0)
2023-01-18 17:09:49 +08:00
err := d.sql(refs.SqlDB.NewSession()).In("config_id", list).Find(&configs)
2022-03-01 13:50:13 +08:00
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return nil
}
return &configs
}
// Remove 删除数据
func (d ConfigDao) Delete(list []int64) bool {
2023-01-18 17:09:49 +08:00
session := refs.SqlDB.NewSession()
2022-03-01 13:50:13 +08:00
session.Begin()
2023-01-18 17:21:12 +08:00
_, err := session.In("config_id", list).Delete(&dataobject.SysConfig{})
2022-03-01 13:50:13 +08:00
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
session.Rollback()
return false
}
session.Commit()
return true
}
// SelectAll 查询所有数据
2023-01-18 17:21:12 +08:00
func (d ConfigDao) SelectAll() *[]dataobject.SysConfig {
configs := make([]dataobject.SysConfig, 0)
2023-01-18 17:09:49 +08:00
session := refs.SqlDB.NewSession()
2022-03-01 13:50:13 +08:00
err := session.Find(&configs)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2022-03-01 13:50:13 +08:00
return nil
}
return &configs
}
2023-01-18 17:09:49 +08:00
func init() {
// 查询配置数据存入到缓存中
configDao := new(ConfigDao)
configSession := configDao.sql(refs.SqlDB.NewSession())
2023-01-18 17:21:12 +08:00
configs := make([]*dataobject.SysConfig, 0)
2023-01-18 17:09:49 +08:00
err := configSession.Find(&configs)
if err != nil {
2023-01-18 17:46:25 +08:00
logging.ErrorLog(err)
2023-01-18 17:09:49 +08:00
return
}
for _, sysConfig := range configs {
2023-01-18 18:02:58 +08:00
refs.RedisDB.SET(constant.RedisConst{}.GetRedisConfigKey()+sysConfig.ConfigKey, cache.StructToJson(map[string]interface{}{
2023-01-18 17:09:49 +08:00
"configId": sysConfig.ConfigId,
"configName": sysConfig.ConfigName,
"configKey": sysConfig.ConfigKey,
"configValue": sysConfig.ConfigValue,
"configType": sysConfig.ConfigType,
"remark": sysConfig.Remark,
}))
}
}