zoukankan      html  css  js  c++  java
  • gin+gorm 用户服务

    package main
    
    import (
    	"fmt"
    	"github.com/gin-gonic/gin"
    	"github.com/jinzhu/gorm"
    	_ "github.com/jinzhu/gorm/dialects/mysql"
    )
    
    var db *gorm.DB
    var err error
    
    type User struct {
    	ID int `json:id`
    	Name string `json:"name"`
    	Age int `json:"age"`
    	Sex int `json:"sex"`
    }
    
    func main()  {
    
    	db,_ = gorm.Open("mysql","root:root@tcp(192.168.40.10:3306)/wang?charset=utf8&parseTime=True&loc=Local")
    	
    	if err != nil{
    		fmt.Println(err)
    		return
    	} else {
    		fmt.Println("connect success")
    	}
    	defer db.Close()
    
    	db.AutoMigrate(&User{})
    
    	r := gin.Default()
    
    	// 用户管理
    	r.GET("/",getUserList)
    	r.GET("/user/:id",getUserInfo)
    	r.GET("/users",getUserList)
    	r.POST("/user",addUser)
    	r.PUT("/user/:id",editUser)
    	r.DELETE("/user/:id",deleteUser)
    
    	r.Run(":8080")
    }
    
    // 用户信息
    func getUserInfo(c *gin.Context)  {
    	var user User
    	id := c.Params.ByName("id")
    	if err := db.Where("id = ?",id).First(&user).Error; err != nil{
    		c.AbortWithStatus(404)
    		fmt.Println(err)
    	} else {
    		c.JSON(200,user)
    	}
    }
    
    // 用户列表
    func getUserList(c *gin.Context)  {
    	var users []User
    	if err := db.Find(&users).Error;err!=nil{
    		c.AbortWithStatus(404)
    		fmt.Println(err)
    	} else {
    		c.JSON(200,users)
    	}
    
    }
    // 用户新增
    func addUser(c *gin.Context)  {
    	var user User
    	c.BindJSON(&user)
    	db.Create(&user)
    	c.JSON(200,user)
    }
    
    // 用户编辑
    func editUser(c *gin.Context)  {
    	var user User
    	id := c.Params.ByName("id")
    	if err := db.Where("id = ?",id).First(&user).Error;err !=nil{
    		c.AbortWithStatus(404)
    		fmt.Println(err)
    	}
    	c.BindJSON(&user)
    	db.Save(&user)
    	c.JSON(200,user)
    }
    // 用户删除
    func deleteUser(c *gin.Context)  {
    	var user User
    	id := c.Params.ByName("id")
    	d := db.Where("id  = ?",id).Delete(&user)
    	fmt.Println(d)
    	c.JSON(200,gin.H{"id #" + id: "deleted"})
    }
    

      

  • 相关阅读:
    macbook如何清理磁盘中的“容器中的其他宗卷”
    Maven本地仓库与远程仓库配置
    查看MySQL库、表所占磁盘空间大小
    数据库操作
    Mac Mysql初始密码重置
    Vue 性能优化经验总结
    【读书笔记】对象创建摘录
    【读书笔记】 函数柯里化
    js实现仿windows文件按名称排序
    本来想偷懒的今天,想了想,还是写一篇吧,前端登录界面,用的BOOTSTRAP
  • 原文地址:https://www.cnblogs.com/brady-wang/p/13074210.html
Copyright © 2011-2022 走看看