golang Gorm框架

全功能 ORM关联 (Has One,Has Many,Belongs To,Many To Many,多态,单表继承)Create,Save,Update,Delete,Find 中钩子方法支持 Preload、Joins 的预加载事务,嵌套事务,Save Point,Rollback To Saved PointContext,预编译模式,DryRun 模式。
摘要由CSDN通过智能技术生成

1.gorm介绍

1.1介绍
全功能 ORM
关联 (Has One,Has Many,Belongs To,Many To Many,多态,单表继承)
Create,Save,Update,Delete,Find 中钩子方法
支持 Preload、Joins 的预加载
事务,嵌套事务,Save Point,Rollback To Saved Point
Context,预编译模式,DryRun 模式
批量插入,FindInBatches,Find/Create with Map,使用 SQL 表达式、Context Valuer 进行 CRUD
SQL 构建器,Upsert,数据库锁,Optimizer/Index/Comment Hint,命名参数,子查询
复合主键,索引,约束
Auto Migration
自定义 Logger
灵活的可扩展插件 API:Database Resolver(多数据库,读写分离)、Prometheus…
每个特性都经过了测试的重重考验
开发者友好
1.2安装
go get -u gorm.io/gorm
go get -u gorm.io/driver/sqlite

2.使用

2.1创建表
package main

import (
	"fmt"

	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

//模型结构
type Student struct {
	Id   int
	Name string
	Age  int
}

type User struct {
	gorm.Model
	Name string `gorm:"type:varchar(20);not null"`
	Telephone string `gorm:"varchar(110;not null;unique"`
	Password string `gorm:"size:255;not null"`
}



func main() {
	//使用dsn连接到数据库,grom自带的数据库池
	//账号:密码@连接方式(ip地址:端口号)/数据库?语言方式,时区(未设置时区的话采用8小时制度)
	dsn := "root:mysql@tcp(127.0.0.1:3306)/gotest?charset=utf8mb4&parseTime=True&loc=Local"
	conn, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) //使用mysq连接数据库,第二个参数可以增加更多的配置(可有可无)
	if err != nil {
		fmt.Println(err)
	}
	conn.AutoMigrate(&Student{}) //创建表?判断是否表结构存在
}

//多表创建
db.AutoMigrate(&Company{}, &Worker{})
2.2.添加数据
stu := &Student{
		Id:   3,
		Name: "li333",
		Age:  30,
	}
	res := conn.Create(stu) //向数据库中插入数据  ,它的返回值只有一个类型,没有error类型
	//注:如果上面写成stu := Student{...},则这里写成Create(&stu)

	if res.Error != nil { //判断是否插入数据出错
		fmt.Println(res.Error)
	}
2.3.查询数据
var student Student
	//查询First查询一条
	conn.First(&student)
	fmt.Println(student)
	fmt.Println(student.Id)
	//条件查询
	res := conn.First(&student, "name=? and id=?", "yang", 1)
	fmt.Println(res)
 //查询所有 Find
	var stu []Student
	conn.Table("students").Find(&stu)
	for _, v := range stu {
   
		fmt.Println(v.Name)
	}

 // IN
	var students []Student
	conn.Table("students").Where("name IN ?", []string{
   "abc", "bili"}).Find(&students)
	fmt.Println(students)

	// LIKE
	db.Where("name LIKE ?", "%jin%").
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,以下是使用 Golang web 框架 Gin 和 MySQL 数据库实现登录注册的示例代码: ```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` 分别为用户名和密码。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值