golang工程组件篇对象关系映射gorm之基于orm的CRUD与原生SQL

GORM是Go语言中最流行的ORM(Object-Relational Mapping)框架之一,它提供了基于结构体的CRUD操作以及原生SQL查询的功能。在本文中,我们将探讨如何使用GORM进行基于ORM的CRUD操作和原生SQL查询。

  1. 基于ORM的CRUD

使用GORM进行基于ORM的CRUD非常简单,只需定义一个模型并调用相应方法即可。以下是一个示例代码:

type User struct {
    gorm.Model
    Name string `gorm:"not null"`
    Age  int
}

func main() {
    // 连接数据库
    db, err := gorm.Open(mysql.Open("user:password@tcp(host:port)/database"), &gorm.Config{})
    if err != nil {
        panic(err)
    }

    // 自动迁移表格(如果不存在则创建)
    db.AutoMigrate(&User{})

    // 创建记录
    user := User{Name: "Alice", Age: 20}
    db.Create(&user)

    // 查询记录
    var result User
    db.First(&result, "name = ?", "Alice")

	// 更新记录
	db.Model(&result).Update("Age", 21)

	// 删除记录
	db.Delete(&result)
}

这个示例演示了如何使用GORM进行创建、读取、更新和删除(CRUD)操作。该代码创建了一个名为User的模型,并使用db.Create()方法来创建新纪录。然后,通过调用db.First()方法来查找第一条满足条件(name = "Alice")的记录。db.Model()Update()方法用于更新该记录,最后通过调用db.Delete()方法删除它。

  1. 原生SQL查询

除了提供基于ORM的CRUD操作外,GORM还支持原生SQL查询。这对于需要执行复杂查询或在性能方面有要求的应用程序非常有用。以下是一个示例代码:

func main() {
    // 连接数据库
    db, err := gorm.Open(mysql.Open("user:password@tcp(host:port)/database"), &gorm.Config{})
    if err != nil {
        panic(err)
    }

	// 执行原生SQL查询并获取结果集
	var users []User
	db.Raw("SELECT * FROM users WHERE age > ?", 18).Scan(&users)

	// 输出结果集
	for _, user := range users {
		fmt.Printf("%d %s %d\n", user.ID, user.Name, user.Age)
	}
}

这个示例演示了如何使用GORM进行原生SQL查询。该代码通过调用db.Raw()方法来执行原生SQL语句,并将结果扫描到一个名为users的切片中。最后,遍历切片并输出每个用户的ID、姓名和年龄信息。

总结

GORM是一款强大而灵活的ORM框架,提供了基于结构体的CRUD操作以及原生SQL查询功能。无论你是需要快速开发应用程序还是处理高负载场景下的复杂数据查询,GORM都能够满足你的需求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值