码农笔录博客源码
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

78 строки
2.3 KiB

6 лет назад
package service
import (
"github.com/astaxie/beego/orm"
"beeblog/models"
)
type UserService struct {
}
6 лет назад
func (this *UserService) GetUser(id int64) (*models.User, error) {
6 лет назад
o := orm.NewOrm()
6 лет назад
user := &models.User{Id: id}
6 лет назад
err := o.Read(user)
6 лет назад
return user, err
6 лет назад
}
6 лет назад
func (this *UserService) FindByUserName(username string) (*models.User, error) {
6 лет назад
o := orm.NewOrm()
qs := o.QueryTable(&models.User{})
var users []*models.User
_, err := qs.Filter("UserName", username).All(&users)
if err != nil {
return nil, err
}
if len(users) != 0 {
return users[0], nil
}
return nil, nil
}
6 лет назад
func (this *UserService) SaveUser(user *models.User) error {
6 лет назад
o := orm.NewOrm()
id, eror := o.Insert(user)
if eror != nil {
return eror
} else {
user.Id = id
o.Commit()
}
return nil
}
6 лет назад
6 лет назад
func (this *UserService) CountBlog(uid int64) {
6 лет назад
o := orm.NewOrm()
6 лет назад
browses := 0
6 лет назад
o.Raw("UPDATE `auth_user` SET `blog_count` = (SELECT count(id) num FROM blog where delflag = 0 and user_id =? ) WHERE `id` = ? ", uid, uid).QueryRow(&browses)
6 лет назад
return
}
6 лет назад
func (this *UserService) CountBrows(uid int64) {
6 лет назад
o := orm.NewOrm()
browses := 0
6 лет назад
o.Raw("UPDATE `auth_user` SET `blog_browes` = (select SUM(browses) browses from blog where user_id = ?) WHERE `id` = ? ", uid, uid).QueryRow(&browses) //获取总条数
6 лет назад
return
}
6 лет назад
func (this *UserService) CountComments(uid int64,bid int64) {
6 лет назад
o := orm.NewOrm()
browses := 0
6 лет назад
o.Raw("UPDATE `auth_user` SET `blog_comment` = (select count(id) num from comment where cuser_id = ?) WHERE `id` = ? ", uid, uid).QueryRow(&browses) //获取总条数
o.Raw("UPDATE `blog` SET `comments` = (select count(id) num from comment where blog_id = ?) WHERE `id` = ? ", bid, bid).QueryRow(&browses) //获取总条数
6 лет назад
return
6 лет назад
}
6 лет назад
func (this *UserService) CountLike(uid int64,bid int64) {
6 лет назад
o := orm.NewOrm()
browses := 0
6 лет назад
o.Raw("UPDATE `auth_user` SET `blog_like` = (select count(id) num from tb_like where user_id = ?) WHERE `id` = ?", uid, uid).QueryRow(&browses)
o.Raw("UPDATE `blog` SET `likes` = (select count(id) num from tb_like where blog_id = ?) WHERE `id` = ?", bid, bid).QueryRow(&browses)
6 лет назад
return
6 лет назад
}
6 лет назад
6 лет назад
func (this *UserService) EditUser(user *models.User) (int64, error) {
6 лет назад
return orm.NewOrm().Update(user)
}
6 лет назад
6 лет назад
func (this *UserService) EditHeadImg(user *models.User) (int64, error) {
6 лет назад
return orm.NewOrm().Update(user,"Headimg")
}