百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Go - Gin框架 - Gorm介绍与使用(ginkgo框架)

ccwgpt 2024-09-18 12:20 28 浏览 0 评论

前言 : gorm是Golang语言中一款性能极好的ORM库,对开发人员相对是比较友好的;另外一个orm库xorm也非常出名。

一、GORM介绍和快速入门

1.1、功能概览

  • 全功能ORM(无限接近)
  • 关联(Has One, Has Many, Belongs To, Many To Many, 多态)
  • 钩子函数Hook(在创建/保存/更新/删除/查找之前或之后)
  • 预加载
  • 事务
  • 复合主键
  • SQL 生成器
  • 数据库自动迁移
  • 自定义日志
  • 可扩展性, 可基于 GORM 回调编写插件
  • 所有功能都被测试覆盖
  • 开发者友好
  • 1.2、安装

    我们都知道,在golang中需要使用一些驱动包来对指定数据库进行操作,比如MySQL需要使用github.com/go-sql-driver/mysql库,而Sqlite需要使用github.com/mattn/go-sqlite3库来支持,不过好在gorm框架中对各个驱动包进行了简单包装,可以让我们在写程序时可以更方便的管理驱动库.

    支持的数据库以及导入路径如下:

    • mysql: github.com/jinzhu/gorm/dialects/mysql
    • postgres: github.com/jinzhu/gorm/dialects/postgres
    • sqlite: github.com/jinzhu/gorm/dialects/sqlite
    • sqlserver: github.com/jinzhu/gorm/dialects/mssql

    注意:gorm框架只是简单封装了数据库的驱动包,在安装时仍需要下载原始的驱动包

    # 由于在项目中使用mysql比较多,这里使用mysql进行数据存储
    $ go get -u github.com/jinzhu/gorm
    $ go get -u github.com/go-sql-driver/mysql

    1.3、快速入门

    package main
    import (
        "fmt"
        "time"
    
        "github.com/jinzhu/gorm"
        _ "github.com/jinzhu/gorm/dialects/mysql"
    )
    
    
    // 定义一个数据模型(user表)
    // 列名是字段名的蛇形小写(PassWd->pass_word)
    type User struct {
        Id          uint        `gorm:"AUTO_INCREMENT"`
        Name        string      `gorm:"size:50"`
        Age         int         `gorm:"size:3"`
        Birthday    *time.Time
        Email       string      `gorm:"type:varchar(50);unique_index"`
        PassWord    string      `gorm:"type:varchar(25)"`
    }
    
    var db *gorm.DB
    
    func main() {
        db,err := gorm.Open("mysql","root:bgbiao.top@(127.0.0.1:13306)/test_api?charset=utf8&parseTime=True&loc=Local")
        if err != nil {
            fmt.Errorf("创建数据库连接失败:%v",err)
    
        }
    
        defer db.Close()
    
        // 自动迁移数据结构(table schema)
        // 注意:在gorm中,默认的表名都是结构体名称的复数形式,比如User结构体默认创建的表为users
        // db.SingularTable(true) 可以取消表名的复数形式,使得表名和结构体名称一致
        db.AutoMigrate(&User{})
    
    
        // 添加唯一索引
        db.Model(&User{}).AddUniqueIndex("name_email", "id", "name","email")
    
        // 插入记录
        db.Create(&User{Name:"bgbiao",Age:18,Email:"bgbiao@bgbiao.top"})
        db.Create(&User{Name:"xxb",Age:18,Email:"xxb@bgbiao.top"})
    
        var user User
        var users []User
        // 查看插入后的全部元素
        fmt.Printf("插入后元素:\n")
        db.Find(&users)
        fmt.Println(users)
    
        // 查询一条记录
        db.First(&user,"name = ?","bgbiao")
        fmt.Println("查看查询记录:",user)
    
        // 更新记录(基于查出来的数据进行更新)
        db.Model(&user).Update("name","biaoge")
        fmt.Println("更新后的记录:",user)
    
        // 删除记录
        db.Delete(&user)
    
        // 查看全部记录
        fmt.Println("查看全部记录:")
    
        db.Find(&users)
        fmt.Println(users)
    }


    相关推荐

    5 分钟搭建 Node.js 微服务原型(node 微服务架构)

    微服务已成为在Node.js中构建可扩展且强大的云应用的主流方法。同时也存在一些门槛,其中一些难点需要你在以下方面做出决策:组织项目结构。将自定义服务连接到第三方服务(数据库,消息代理等)处理微服...

    当前的前端,真的不配叫程序员吗?

    今天看到一个比较令人震惊的帖子,说前端不配叫程序员,令我很吃鲸,是谁我就不说了,帖子出处是一个大龄程序员组里面的,想想也不觉得奇怪了,毕竟对于年龄比较大的程序员来说,前端起步比较晚,最开始就是一个切图...

    聊聊asp.net中Web Api的使用(asp.net core web api教程)

    扯淡随着app应用的崛起,后端服务开发的也越来越多,除了很多优秀的nodejs框架之外,微软当然也会在这个方面提供更便捷的开发方式。这是微软一贯的作风,如果从开发的便捷性来说的话微软是当之无愧的老大哥...

    NodeJS中,listen Access:permission denied解决办法

    错误描述:Win10系统,NodeJS程序。使用express框架开发的http服务器,启动时出现错误提示“listenAccess:permissiondenied"。错误原因:这是由于...

    Hono — 下一代高性能web框架(天融信下一代vnp)

    最近公司可能要有变革,要统计我们的技能。真的是很无语,但是有没有办法。哎,问豆包吧提起Hono大家可能很陌生,这是什么?但是我提到Expressjs、nodejs想必前端小伙伴很熟悉啊。那么Hon...

    生活例子说明线程,简单明了(列举一个日常生活中的例子以程序的形式表示)

    1.程序设计的目标在我看来单从程序的角度来看,一个好的程序的目标应该是性能与用户体验的平衡。当然一个程序是否能够满足用户的需求暂且不谈,这是业务层面的问题,我们仅仅讨论程序本身。围绕两点来展开,性能...

    Node实战006:自定义模块的创建和使用详解

    Node的应用是由模块组成的,每个文件的定义都是一个模块(module变量代表当前模块)并有自己的作用域。Node遵循commonjs的模块规范,用来隔离每个模块的作用域,使每一个模块在自身的命名空间...

    Node.js基本内容和知识点(node.js的概念)

    简单的说Node.js就是运行在服务端的JavaScript,起初段定位是后端开发语言,由于技术的不够成熟,一般小型项目会完全使用node.js作为后台支撑,大项目中,运行不够稳定,不会轻易使用...

    干货 | 如何利用Node.js 构建分布式集群

    引言在软件定义的世界里,企业通过Web应用和移动应用程序来提供大部分的服务,Node.js迅速成为时下最为流行的一个平台之一,就和它可以搭建响应速度快、易于扩展的web应用和移动应用有很大关系,并凭...

    nodejs mongodb 实现简易留言板(node.js留言板)

    一个朋友问了一下mongodb的一些操作问题我就做了下面这个简单的留言板给他做一个实例希望能帮助到他express的框架就不说了express的问题请移步nodejs之expressht...

    nodejs mqtt 智能售货机系统物联网控制系统源码分享

    智能售货机系统(Moleintelligentvendingmachinesystem)是一套物联网控制系统性的解决方案。主要涉及到的语言和库有c,c++,js,nodejs,vue.js,...

    为什么 Node.js 这么火,而同样异步模式 Python 框架 Twisted 却十几年一直不温不火?

    说nodejs只是靠营销的是否太天真了些?当初nodejs出来的时候各种BUG,我简单的测试其大文件传输都会出现各种问题。而同時期的其他阵营早就甩其几条街了。但是为什么却能一直不断发展壮大?...

    2020年14个最有用的NodeJS库(node用什么数据库)

    Express快速,简单,极简的节点Web框架对…有好处·易于处理多种类型的请求,例如GET,PUT,POST和DELETE请求·快速构建单页,多页和混合Web应用程序每周下载1100万Lice...

    连载:2016年最好的JS框架和库(下)

    继续上一期的介绍:Agility.jsAgility.js是专为JS服务的MVC库,你可以免费编写可再用和可维护的浏览器代码,Agility支持Js,样式(CSS)、内容(HTML)和行为(JS)。C...

    awesome-nodejs 终极资源库:60K+星标的开发者宝藏

    Node.js终极资源库:60K+星标的开发者宝藏引言在GitHub上,有一个备受瞩目的Node.js资源仓库,以其惊人的60.6k星标量和6kfork量,成为了Node.js开发者的必备参考。这个...

    取消回复欢迎 发表评论: