37 Star 209 Fork 108

狂奔的蜗牛./anytunnel

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
user_role.go 1.33 KB
一键复制 编辑 原始数据 按行查看 历史
arraykeys 提交于 2019-08-08 17:13 +08:00 . init
package models
import (
"github.com/snail007/go-activerecord/mysql"
"time"
)
type UserRole struct {
UserRoleID uint `orm:"pk"` // user_role_id
UserID uint64 // user_id
RoleID uint // role_id
IsDelete int8 // is_delete
CreateTime uint // create_time
UpdateTime uint // update_time
}
func (this *UserRole) GetUserRolesByUserId(userId string) (userRoles []map[string]string, err error) {
db := G.DB();
var rs *mysql.ResultSet
rs, err = db.Query(db.AR().From("user_role").Where(map[string]interface{}{
"user_id": userId,
"is_delete": 0,
}))
if err != nil {
return
}
userRoles = rs.Rows()
return
}
// 插入 user_id 和 role_id 对应关系
func (this *UserRole) Insert(userId string, roleIds []string) (res bool, err error) {
res = false
db := G.DB()
//先删除
_, err = db.Exec(db.AR().Delete("user_role", map[string]interface{}{
"user_id": userId,
}))
if(err != nil) {
return
}
//添加
userRoles := []map[string]interface{}{}
for _, roleId := range roleIds {
userRole := map[string]interface{}{
"role_id" : roleId,
"user_id" : userId,
"is_delete" : 0,
"create_time": time.Now().Unix(),
"update_time": time.Now().Unix(),
}
userRoles = append(userRoles, userRole)
}
_, err = db.Exec(db.AR().InsertBatch("user_role", userRoles))
if err != nil {
return
}
res = true
return
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
JavaScript
1
https://gitee.com/snail/anytunnel.git
git@gitee.com:snail/anytunnel.git
snail
anytunnel
anytunnel
8296c84158a6

搜索帮助