[GO] golang练习项目-gorm与mysql的增删查改操作

下面代码放在models包下的users.go中

表结构和struct字段是一致的,把表字段的下划线变成首字母大写的驼峰命名

创建,查找,删除,更新用户,见下面的具体方法

 

复制代码
package models

import (
    _ "github.com/jinzhu/gorm/dialects/mysql"
)
type User struct {
    Model
    Name string `json:"name"`
    Password string `json:"password"`
    Nickname string `json:"nickname"`
    Avator string `json:"avator"`
    RoleName string `json:"role_name"`
}
func CreateUser(name string,password string,avator string,nickname string){
    user:=&User{
        Name:name,
        Password: password,
        Avator:avator,
        Nickname: nickname,
    }
    DB.Create(user)
}
func UpdateUser(id string,name string,password string,avator string,nickname string){
    user:=&User{
        Name:name,
        Avator:avator,
        Nickname: nickname,
    }
    if password!=""{
        user.Password=password
    }
    DB.Model(&User{}).Where("id = ?",id).Update(user)
}
func FindUser(username string)User{
    var user User
    DB.Where("name = ?", username).First(&user)
    return user
}
func FindUserById(id interface{})User{
    var user User
    DB.Where("id = ?", id).First(&user)
    return user
}
func DeleteUserById(id string){
    DB.Where("id = ?",id).Delete(User{})
}
func FindUsers()[]User{
    var users []User
    DB.Order("id desc").Find(&users)
    return users
}
func FindUserRole(query interface{},id interface{})User{
    var user User
    DB.Select(query).Where("user.id = ?", id).Joins("join user_role on user.id=user_role.user_id").Joins("join role on user_role.role_id=role.id").First(&user)
    return user
}
复制代码

 

posted @   唯一客服系统开发笔记  阅读(628)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
历史上的今天:
2019-08-24 [Linux] nginx的try_files指令实现隐藏index.php的重写
2018-08-24 [PHP] 数据结构-线性表的顺序存储结构PHP实现
点击右上角即可分享
微信分享提示
1
chat with us