golang gin使用gorm+mysql 实现增加 删除更新 查询

3 篇文章 0 订阅
1 篇文章 0 订阅

核心代码

package main

import (
	"fmt"
	"github.com/gin-gonic/gin"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
	"net/http"
	"time"
)

type Product struct {
	Id             int       `gorm:"primaryKey;autoIncrement" json:"id"`
	Number         string    `gorm:"unique"  json:"number"`
	Category       string    `gorm:"type:varchar(255);not null json:"category"`
	Name           string    `gorm:"type:varchar(20);not null" json:"name"`
	MadeIn         string    `gorm:"type:varchar(128);not null" json:"made_in"`
	ProductionTime time.Time `json:"production_time"`
}

var gormDB * gorm.DB
func init() {
	var err error
	dsn := "golang:golang@tcp(127.0.0.1:3306)/golang?charset=utf8mb4&parseTime=True&loc=Local"
	gormDB, err= gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		fmt.Println("连接数据库出错:",err.Error())
		return
	}

}
func main() {

	r:= gin.Default()

	r.POST("/insert",insertData)
	r.GET("/get",get)
	r.GET("/getMult",getMult)
	r.PUT("/update",update)
	r.DELETE("/delete",delete1)

	r.Run()

}

func delete1(c *gin.Context) {
	catchException(c)

	id := c.Query("id")

	tx := gormDB.Where("id=?", id).Delete(&Product{})
	if tx.RowsAffected > 0 {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusOK,
			"msg":"删除成功",
			"data":"ok",
		})
		return
	}else{
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusBadGateway,
			"msg":"删除失败",
			"data":tx.Error,
		})
	}

	return
}

func update(c *gin.Context) {
	catchException(c)

	var p Product
	err := c.Bind(&p)
	if err != nil {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusBadGateway,
			"msg":"参数错误",
			"data":err,
		})
		return
	}

	fmt.Println(p)
	updates := gormDB.Where("name=?", p.Name).Updates(&p)
	if updates.RowsAffected > 0 {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusOK,
			"msg":"更新成功",
			"data":"ok",
		})
		return
	}else {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusOK,
			"msg":"更新失败",
			"data":updates.Error,
		})
		return
	}

}

func getMult(c *gin.Context) {
	catchException(c)

	category := c.Query("category")
	product := make([]Product,10)
	tx := gormDB.Where("category=?", category).Find(&product).Limit(10)

	if tx.Error != nil {
		c.JSON(http.StatusOK,gin.H{
			"code":http.StatusBadGateway,
			"msg":"error",
			"data":tx.Error,
		})
		return
	}

	c.JSON(http.StatusOK,gin.H{
		"code":http.StatusOK,
		"msg":"success",
		"data":product,
	})
	return




}

func get(c *gin.Context) {
	catchException(c)


	var product Product
	name := c.Query("name")
	gormDB.Where("name=?", name).First(&product)
	//gormDB.Where("name=?", name).Find(&product)


	c.JSON(http.StatusOK,gin.H{
		"code":http.StatusOK,
		"msg":"success",
		"data":product,
	})

	return


}

func insertData(c *gin.Context) {

	catchException(c)


	var p Product
	err := c.Bind(&p)
	if err != nil {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusBadGateway,
			"msg":"参数错误",
			"data":err,
		})
		return
	}
	// insert data
	create := gormDB.Create(&p)
	if create.RowsAffected > 0 {
		c.JSON(http.StatusBadGateway,gin.H{
			"code":http.StatusOK,
			"msg":"添加成功",
			"data":true,
		})
		return

	}

}


func catchException(c *gin.Context){
	// 捕获异常
	defer func() {
		err := recover()
		if err != nil {
			c.JSON(http.StatusBadGateway,gin.H{
				"code":http.StatusBadGateway,
				"msg":err,
				"data":err,
			})
		}
	}()
}


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用 Golang web 框架 GinMySQL 数据库实现登录注册的示例代码: ```go package main import ( "database/sql" "fmt" "log" "github.com/gin-gonic/gin" _ "github.com/go-sql-driver/mysql" ) type User struct { ID uint `json:"id" gorm:"primary_key"` Username string `json:"username"` Password string `json:"password"` } func main() { // 连接 MySQL 数据库 db, err := sql.Open("mysql", "root:password@tcp(127.0.0.1:3306)/test?charset=utf8mb4&parseTime=True&loc=Local") if err != nil { log.Fatal(err) } defer db.Close() // 初始化 Gin 引擎 r := gin.Default() // 注册路由 r.POST("/register", func(c *gin.Context) { var user User if err := c.ShouldBindJSON(&user); err != nil { c.JSON(400, gin.H{"error": err.Error()}) return } if user.Username == "" || user.Password == "" { c.JSON(400, gin.H{"error": "username and password cannot be empty"}) return } // 查询用户名是否已经存在 var count int if err := db.QueryRow("SELECT COUNT(*) FROM users WHERE username = ?", user.Username).Scan(&count); err != nil { c.JSON(500, gin.H{"error": err.Error()}) return } if count > 0 { c.JSON(400, gin.H{"error": "username already exists"}) return } // 插入新用户信息 result, err := db.Exec("INSERT INTO users (username, password) VALUES (?, ?)", user.Username, user.Password) if err != nil { c.JSON(500, gin.H{"error": err.Error()}) return } // 返回新用户的 ID id, _ := result.LastInsertId() c.JSON(200, gin.H{"id": id}) }) r.POST("/login", func(c *gin.Context) { var user User if err := c.ShouldBindJSON(&user); err != nil { c.JSON(400, gin.H{"error": err.Error()}) return } if user.Username == "" || user.Password == "" { c.JSON(400, gin.H{"error": "username and password cannot be empty"}) return } // 查询用户信息 var u User if err := db.QueryRow("SELECT id, username, password FROM users WHERE username = ?", user.Username).Scan(&u.ID, &u.Username, &u.Password); err != nil { c.JSON(400, gin.H{"error": "invalid username or password"}) return } // 检查密码是否正确 if u.Password != user.Password { c.JSON(400, gin.H{"error": "invalid username or password"}) return } c.JSON(200, gin.H{"id": u.ID, "username": u.Username}) }) // 启动服务 if err := r.Run(":8080"); err != nil { log.Fatal(err) } } ``` 在上面的代码中,我们定义了一个 `User` 结构体来表示用户信息,包含 ID、用户名和密码。首先,我们连接MySQL 数据库,并使用 Gin 框架注册了两个路由:`/register` 和 `/login`。`/register` 路由用于新用户注册,会检查用户名是否已经存在,如果不存在则将用户信息插入到数据库中,并返回新用户的 ID。`/login` 路由用于用户登录,会查询用户名是否存在,并检查密码是否正确,如果正确则返回用户信息。 你需要注意修改上面代码中数据库连接的用户名和密码,并且需要创建一个名为 `users` 的表,包含 `id`、`username` 和 `password` 三个字段。 你可以将以上代码保存为 `main.go` 文件,然后使用以下命令在本地启动服务器: ``` go run main.go ``` 然后在浏览器或者使用 curl 工具测试 `/register` 和 `/login` 接口,例如: ``` curl -X POST -H "Content-Type: application/json" -d '{"username": "test", "password": "123456"}' http://localhost:8080/register curl -X POST -H "Content-Type: application/json" -d '{"username": "test", "password": "123456"}' http://localhost:8080/login ``` 以上命令中的 `test` 和 `123456` 分别为用户名和密码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值