Files
2022-01-28 16:59:15 +08:00

50 lines
1.3 KiB
Go

package model
import (
"SciencesServer/app/common/model"
"SciencesServer/serve/orm"
"fmt"
)
type UserExpert struct {
*model.UserExpert
}
type (
// UserExpertInfo 专家信息
UserExpertInfo struct {
UserExpertID uint64 `json:"-"`
*model.ManageExpert
}
)
func (m *UserExpert) Settled(uid uint64) (*UserSettledInfo, error) {
out := new(UserSettledInfo)
err := orm.GetDB().Table(m.TableName()+" AS u").
Select("u.id", "c.examine_status", "c.examine_remark").
Joins(fmt.Sprintf("LEFT JOIN %s AS c ON u.expert_id = c.id", model.NewManageExpert().TableName())).
Where("u.uid = ?", uid).
Where("u.is_deleted = ?", model.DeleteStatusForNot).
Order("u.id " + model.OrderModeToDesc).Limit(1).
Scan(out).Error
return out, err
}
// Expert 专家信息
func (m *UserExpert) Expert(uid uint64) (*UserExpertInfo, error) {
out := new(UserExpertInfo)
err := orm.GetDB().Table(m.TableName()+" AS u").
Select("u.id AS user_expert_id", "c.*").
Joins(fmt.Sprintf("LEFT JOIN %s AS c ON u.expert_id = c.id", model.NewManageExpert().TableName())).
Where("u.uid = ?", uid).
Where("u.is_deleted = ? AND u.invalid_status = ?", model.DeleteStatusForNot, model.InvalidStatusForNot).
Scan(out).Error
return out, err
}
func NewUserExpert() *UserExpert {
return &UserExpert{model.NewUserExpert()}
}