首页 > 其他分享 >bubble小清单后端代码

bubble小清单后端代码

时间:2022-11-27 12:22:46浏览次数:50  
标签:200 err todo 代码 DB 清单 gin bubble id

bubble小清单后端代码

package main

import (
   "fmt"
   "github.com/gin-gonic/gin"
   "github.com/jinzhu/gorm"
   _"github.com/jinzhu/gorm/dialects/mysql"//别忘加驱动
)
//go mod tidy

//定义全局DB
var(
   DB *gorm.DB
)


//创建模型 Todu model
type Todo struct {
   ID     int    `json:"id"`
   Title  string `json:"title"`
   Status bool   `json:"status"`
}


//链接数据库
func initMySQL() (err error) {
   dsn:="root:123456@tcp(127.0.0.1:3306)/bubble?charset=utf8mb4&parseTime=True&loc=Local"
   DB,err=gorm.Open("mysql",dsn)
   if err!=nil{
      return
   }
   return DB.DB().Ping()
}

func main() {
   //创建数据库
   //sql命令:create database bublle;
   //use bublle;
   //链接数据库
   err:=initMySQL()
   if err != nil {
      fmt.Println(err)
   }

   //延时关闭,程序退出关闭数据库
   defer DB.Close()

   //模型绑定,把模型与数据库的表进行绑定
   DB.AutoMigrate(&Todo{})//todos
    
   //默认路由
   r:=gin.Default()
    
   //告诉gin模板文件引用的静态文件去哪里找
   r.Static("/static","static")
    
   //告诉gin去哪里找模板
   r.LoadHTMLGlob("templates/*")
    
   //GET:请求方式;/:请求的路径
   r.GET("/", func(c *gin.Context) {
      c.HTML(200,"index.html",nil)
   })
    
   //定义一个v1版本api:路由组
   v1Group:=r.Group("v1")
   {
      //添加
      v1Group.POST("/todo", func(c *gin.Context) {
         //前端页面填写待办事项点击提交,会发送请求到这里
         //从请求中把数据拿出来
         //定义存放的变量
         var todo Todo
         //数据绑定
         c.ShouldBind(&todo)
         //存入数据库,返回响应
         if err=DB.Create(&todo).Error;err!=nil{
            c.JSON(200,gin.H{
               "error":err.Error()})
         }else {
            c.JSON(200,todo)
         }
      })
      //查看代办
      v1Group.GET("/todo", func(c *gin.Context) {
         //查询todo这个表的所有数据
         var todoList []Todo
         if err=DB.Find(&todoList).Error;err!=nil{
            c.JSON(200,err.Error())
         }else {
            c.JSON(200,todoList)
         }
      })
      //修改某一个代办事项
      v1Group.PUT("/todo/:id", func(c *gin.Context) {
         id,ok :=c.Params.Get("id")
         if !ok{
            c.JSON(200,gin.H{
               "error":"id不存在"})
            return
         }
         var todo Todo
         if err=DB.Where("id=?",id).First(&todo).Error;err!=nil{
            c.JSON(200,gin.H{
               "error":err.Error()})
            return
         }
         //fmt.Println(todo)
         c.BindJSON(&todo)
         //fmt.Println(todo)
         if err=DB.Save(&todo).Error;err!=nil{
            c.JSON(200,gin.H{
               "error":err.Error()})
         }else {
            c.JSON(200,todo)
         }

      })
      //删除
      v1Group.DELETE("/todo/:id", func(c *gin.Context) {
         id,ok :=c.Params.Get("id")
         if !ok{
            c.JSON(200,gin.H{
               "error":"id不存在"})
            return
         }
         if err=DB.Where("id=?",id).Delete(Todo{}).Error;err!=nil{
            c.JSON(200,gin.H{
               "error":err.Error()})
            return
         }else {
            c.JSON(200,gin.H{
               id:"deleted",
            })
         }
      })
   }

   //启动
   r.Run(":8080")

}

标签:200,err,todo,代码,DB,清单,gin,bubble,id
From: https://www.cnblogs.com/suehoo/p/16929426.html

相关文章