go orm GORM

官网:https://gorm.io/

docs:https://gorm.io/docs/

博客:https://www.tizi365.com/archives/6.html

Go 复制代码
import (
    "fmt"

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

type Product struct {
    gorm.Model
    Code  string
    Price uint
}

func main() {
    fmt.Println("main ...")

    dsn := "act:Q***wsx@tcp(127.0.0.1:3306)/tbname1?charset=utf8mb4&parseTime=True&loc=Local"
    var db, err = gorm.Open(mysql.Open(dsn), &gorm.Config{})
    if err != nil {
       panic("failed to connect database")
    }

    // Migrate the schema
    db.AutoMigrate(&Product{})

    // Create
    db.Create(&Product{Code: "D4211", Price: 100})

    // Read
    var product Product
    db.First(&product, 1)                 // find product with integer primary key
    db.First(&product, "code = ?", "D42") // find product with code D42
    fmt.Println(product)

    // Update - update product's price to 200
    db.Model(&product).Update("Price", 200)
    // Update - update multiple fields
    db.Model(&product).Updates(Product{Price: 200, Code: "F42"}) // non-zero fields
    db.Model(&product).Updates(map[string]interface{}{"Price": 200, "Code": "F42"})

    // Delete - delete product
    db.Delete(&product, 1)

    fmt.Println("success ...")
}
相关推荐
SuniaWang2 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题八:《RAG 系统安全与权限管理:企业级数据保护方案》
java·前端·人工智能·spring boot·后端·spring·架构
南 阳25 分钟前
Python从入门到精通day56
开发语言·python
呆萌很25 分钟前
【GO】if 语句练习题
golang
m0_5698814731 分钟前
C++中的组合模式高级应用
开发语言·c++·算法
m0_7301151136 分钟前
高性能计算负载均衡
开发语言·c++·算法
孞㐑¥44 分钟前
算法—记忆化搜索
开发语言·c++·经验分享·笔记·算法
xushichao19891 小时前
代码覆盖率工具实战
开发语言·c++·算法
2401_857918291 小时前
C++与WebAssembly集成
开发语言·c++·算法
2401_879693871 小时前
C++与微服务架构
开发语言·c++·算法
阿kun要赚马内1 小时前
Python中函数的进阶用法
开发语言·python