探究ORM与GORM:简化数据库操作的力量

数据库 其他数据库
ORM和GORM的组合提供了强大的数据库操作工具,使开发人员能够更轻松地与数据库交互,同时减少了错误和提高了开发效率。

在我目前正在参与的项目中,主要使用了Golang语言开发工程,其中涉及到很多数据库的操作,我主要使用了GORM,在这里也推荐给大家。

在现代软件开发中,与数据库打交道是一个常见的任务。数据库是我们存储和检索数据的关键工具,而访问数据库通常需要大量的编码工作。但是,有一种技术可以极大地简化这个过程,那就是对象关系映射,简称ORM。

什么是ORM?

ORM是一种编程技术,它将对象和关系数据库之间的数据映射起来。它允许开发人员使用面向对象的方式来处理数据库操作,而不必编写复杂的SQL查询。ORM工具将数据库表映射到编程语言中的对象,允许您通过操作对象来执行数据库操作。

ORM的好处:简化数据库访问、提高可移植性、减少错误、提高并发等

开发人员可以使用编程语言的对象和方法来执行数据库操作,而不必深入了解SQL。ORM通常支持多种数据库,使应用程序更容易在不同的数据库系统之间迁移。

golang gorm的使用

GORM的使用

GORM是一种基于Go语言的ORM库,它提供了强大的数据库访问和查询功能。它是Go语言社区中最受欢迎的ORM工具之一,因为它简化了与数据库的交互,并提供了丰富的功能。Gorm也是我目前我在项目中使用的一种ORM,也向大家推荐使用,GORM的主要功能包括:

  • 模型定义:使用Go结构体定义数据库表模型,GORM会自动生成数据库表。
  • 数据库迁移:通过GORM的自动迁移功能,您可以轻松管理数据库模式的变化。
  • 查询构建:GORM提供了强大的查询构建器,允许您执行复杂的数据库查询,包括筛选、排序、分页等。
  • 事务管理:GORM支持事务,确保数据库操作的原子性。

举例说明

通过Gorm创建数据库,只需要定义对应的表即可,例如:

// FwsScenicModel 基础模型
type FwsScenicModel struct {
        ID        uint `gorm:"primaryKey"`
        CreatedAt time.Time
        UpdatedAt time.Time
        DeletedAt sql.NullTime
}

// FwsSysConfigs 系统配置表
type FwsSysConfigs struct {
        FwsScenicModel
        Index        string `gorm:"uniqueIndex;size:255"`
        AiComUrl     string
        WxAppid      string
        WxAppSecret  string
}

// FwsSysUsers 系统用户表
type FwsSysUsers struct {
        FwsScenicModel
        UserId       string
        UserName     string `gorm:"uniqueIndex;size:255"`
        UserPwd      string
        UserRealName string
        UserRoleId   string
        UserState    string
        UserDesc     string
}

连接数据库、创建数据表,迁移数据,例如:

dsn := fmt.Sprintf("%s:%s@tcp(%s:%d)/%s?charset=utf8mb4&parseTime=True&loc=Local",
			    config.MysqlUserName, config.MysqlUserPassword, config.MysqlIP, 
          config.MysqlPort, config.MysqlDbName)
          GormDB, err = gorm.Open(mysql.Open(dsn), &gorm.Config{
            Logger: logger.Default.LogMode(logger.Error), // Print SQL statements
            DisableForeignKeyConstraintWhenMigrating: true,
})
    
GormSqlDB, err = GormDB.DB()
    if err != nil {
        zap.L().Error("dbConnect", zap.Error(err))
        return
	}

GormSqlDB.SetMaxOpenConns(100) // 设置最大打开连接数
GormSqlDB.SetMaxIdleConns(20)  // 设置最大空闲连接数
GormSqlDB.SetConnMaxLifetime(time.Hour)

GormDB.AutoMigrate(&FwsSysUsers{}, &FwsSysRoles{}, &FwsSysConfigs{})

操作数据:

role := FwsSysRoles{
    RoleId:       "0",
    RoleFuncAuth: config.FwsFuncList,
    RoleName:     "超管",
    RoleState:    "enable",
}
// 使用FirstOrCreate来查找,如果不存在则插入,存在则更新
result := GormDB.Where(FwsSysRoles{RoleId: role.RoleId}).FirstOrCreate(&role)
if result.Error == nil {
    if result.RowsAffected == 0 { // 返回插入记录的条数
        updates := map[string]interface{}{
          "role_func_auth": config.FwsFuncList, // 设置要更新的字段
        }
        GormDB.Model(&FwsSysRoles{}).
        Where(FwsSysRoles{RoleId: role.RoleId}).Updates(updates)
  }
}

总的来说,ORM和GORM的组合提供了强大的数据库操作工具,使开发人员能够更轻松地与数据库交互,同时减少了错误和提高了开发效率。

在当今的软件开发中,ORM和GORM已经变得不可或缺。它们不仅简化了数据库操作,还提供了更好的代码组织和可维护性。无论您是刚刚入门还是有经验丰富的开发人员,了解ORM和使用GORM都将大大改善您的数据库访问体验。

责任编辑:姜华 来源: 今日头条
相关推荐

2011-08-01 09:20:12

简化数据库

2023-08-24 08:47:38

2013-11-26 09:47:47

ORM

2011-03-03 11:07:57

Spring数据库访问ORM

2023-10-08 08:11:54

2023-11-02 10:32:27

GoGORM

2018-09-29 15:33:46

图数据库TigerGraph

2010-11-29 11:22:36

SYBASE数据库日志

2016-09-23 13:34:15

PythonORMsqlalchemy

2010-08-31 16:53:54

DHCP数据库

2010-05-28 09:15:50

配置MySQL

2024-01-15 13:34:00

2023-11-07 00:00:00

Dialector参数接口

2009-09-07 15:25:24

MySQL数据库互操作Silverlight

2010-07-22 13:59:14

MS SQL Serv

2010-06-12 17:48:45

MySQL数据库表

2010-06-01 10:47:21

连接MySQL数据库

2010-05-04 11:02:44

Oracle数据库

2011-06-27 13:19:36

OMF托管文件ASM

2011-08-10 15:46:29

数据库
点赞
收藏

51CTO技术栈公众号