通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

有没有什么基于golang的ORM可以和Laravel Eloquent相媲美的

golang是类型严格的语言(好像是这样说吧),同时也没有范型,还没有继承(这点实在不知道是怎么考虑的),基于这两点,golang的ORM不可能像php那样设计,更不可能做到Eloquent那样方便易用。

一、基于golang的ORM可以和Laravel Eloquent相媲美的

golang是类型严格的语言(好像是这样说吧),同时也没有范型,还没有继承(这点实在不知道是怎么考虑的),基于这两点,golang的ORM不可能像php那样设计,更不可能做到Eloquent那样方便易用。

当然,golang有struct的组合可以当集成,但是,假设给DB结构体安装上一堆方法,

type DB struct {

}

func (d *DB) Where(option interface{}) {

        Type := reflect.TypeOf(d).Elem()

    for i := 0; i < Type.NumField(); i++ {

       field := Type.Field(i)

       // do something

    }

}

如果在User结构体组合DB结构体

type User struct {

        *gorm.DB

}

调用user内的where方法实际上是调用了DB内的where方法,反射不出字段,所以,在golang的orm设计中,通常是这样做的:

type DB  struct {}

func (db *DB) where(){}

func (db *DB) select(){}

使用的时候:

type User struct {}  // 定义一个user模型

var db DB //初始化db结构体

var user User // 初始化User结构体

db.where().select(&user)

上面是两个语言在语言层面就造成的差异,看个人习惯,用起来都不难,golang的GORM和XORM都很好用,我做项目的时候用的是GORM。

至于类似Eloquent功能的基于golang的ORM,我找了很久,没有找到,毕竟Eloquent内有非常多的laravel支持类,比如collection类,分页类,

除去collection和分页的话,我感觉GORM基本和Eloquent类似,同样有表间关系,软删除等,当然,我的项目表间关系和软删除用的非常多,其他功能关注不多,也没注意。

至于具体选哪个,你自己测试一下好了。

延伸阅读:

二、resultMap 知识点

resultMap 元素用来描述如何将结果集映射到 Java 对象,使用 resultMap 对列表展示所需的必要字段来进行自动映射,特别是当数据库的字段名和实体类 POJO 中的属性名不一致的情况下,比如角色名称,字段名/列名 column 是 roleName,而 User 对象的属性名则为 userRoleName ,此时就需要做映射。

resultMap 元素的属性值和子节点

id 属性:少数标识,此 id 值用于 select 元素 resultMap 属性的引用。

type 属性:表示该 resultMap 的映射结果类型。

result 子节点:用于标识一些简单属性,其中 column 属性表示从数据库中查询的字段名或别名, property 属性则表示查询出来的字段对应的值赋给实体对象的哪个属性。

说明:MyBatis 中在对查询进行 select 映射的时候,返回类型可以用 resultType 也可以用 resultMap ,resultType和 resultMap 有一定关联和区别,应用场景也不同。

相关文章