golang中gorm.iogorm库

本文介绍了Gorm.io/gorm在Go语言中的应用,包括数据库连接、CRUD操作示例,以及与其类似框架如jinzhu/gorm和go-xorm的对比。强调了gorm.io/gorm的强大功能和性能优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

golang中gorm.io/gorm库

目录

由来

gorm.io/gorm是Go语言中一款优秀的ORM(对象关系映射)库,用于简化数据库操作。该库提供了一组功能强大且易于使用的API,可以帮助开发者轻松地进行数据库连接、CRUD操作和查询等。

多种主要实现用法及其代码示例

  1. 连接数据库并创建表:
package main

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

type User struct {
	ID   uint
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost)/database_name?charset=utf8mb4&parseTime=True&loc=Local"

	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		panic("Failed to connect to database")
	}

	err = db.AutoMigrate(&User{})
	if err != nil {
		panic("Failed to create table")
	}
}
  1. 插入数据:
package main

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

type User struct {
	ID   uint
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost)/database_name?charset=utf8mb4&parseTime=True&loc=Local"

	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		panic("Failed to connect to database")
	}

	user := User{Name: "John", Age: 30}
	result := db.Create(&user)
	if result.Error != nil {
		panic("Failed to insert data")
	}
}
  1. 查询数据:
package main

import (
	"fmt"
	"gorm.io/driver/mysql"
	"gorm.io/gorm"
)

type User struct {
	ID   uint
	Name string
	Age  int
}

func main() {
	dsn := "user:password@tcp(localhost)/database_name?charset=utf8mb4&parseTime=True&loc=Local"

	db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{})
	if err != nil {
		panic("Failed to connect to database")
	}

	var user User
	result := db.First(&user, 1) // 根据ID查询用户信息
	if result.Error != nil {
		panic("Failed to query data")
	}

	fmt.Println(user)
}

其他类似框架

  • gorm.io/gorm是一款流行的Go语言ORM库,除此之外,还有其他类似的ORM库可供选择,例如:
    • github.com/jinzhu/gorm
    • github.com/go-xorm/xorm
    • upper.io/db.v3

详细区别

  • gorm.io/gorm是一个强大的Go语言ORM库,提供了丰富的功能和易用的API。
  • 与其他类似的ORM库相比,gorm.io/gorm具有更好的性能、更全面的文档和更活跃的开发社区。
  • gorm.io/gorm使用更现代化的API设计和更灵活的查询语法,支持多种数据库驱动。

官方链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BigDataMLApplication

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值