| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- /**
- * @Author: zou.yingbin
- * @Create : 2021/1/13 10:51
- * @Modify : 2021/1/13 10:51
- */
- package mtpcache
- import (
- "mtp2_if/db"
- "mtp2_if/logger"
- "sync"
- "time"
- )
- var vUser userName
- type userName struct {
- mtx sync.RWMutex //锁
- data map[int64]string //数据[loginId]accountName
- last time.Time
- }
- type userData struct {
- LOGINID int64 //登录ID
- USERNAME string // 用户名字
- }
- // 加载数据
- func (r *userName) load() {
- now := time.Now()
- // 间隔3秒以上才重新加载
- if d := now.Sub(r.last); d.Seconds() < 3 {
- return
- }
- r.mtx.Lock()
- defer r.mtx.Unlock()
- e := db.GetEngine()
- if e == nil {
- return
- }
- sqlId := "select l.loginid, s.username" +
- " from loginaccount l" +
- " left join systemmanager s" +
- " on l.logincode = s.logincode" +
- " where s.username is not null"
- sData := make([]userData, 0)
- s := e.SQL(sqlId)
- if err := s.Find(&sData); err != nil {
- logger.GetLogger().Errorf("cache load usrname, %v", err)
- } else {
- r.data = make(map[int64]string)
- for i := range sData {
- r.data[sData[i].LOGINID] = sData[i].USERNAME
- }
- r.last = time.Now()
- }
- }
- func (r *userName) get(loginId int64) string {
- r.mtx.RLock()
- defer r.mtx.RUnlock()
- if r.data == nil {
- return ""
- }
- if v, ok := r.data[loginId]; ok {
- return v
- }
- return ""
- }
- // 根据登录ID获取名称
- func GetUserName(loginId int64) string {
- if v := vUser.get(loginId); v !=""{
- return v
- }else{
- vUser.load()
- }
- return vUser.get(loginId)
- }
|