几周后我才了解到 GORM 作为数据库 ORM。检查代码内部后,每个命令(limit、order、where、or、select 等)都通过克隆当前数据库返回新实例。
这里有人知道克隆数据库而不是使用当前实例的主要目的是什么吗?
当我有命令 select、where、limit、order、join 时,这将是克隆数据库实例的 5 倍。AFAIK,在内存上创建对象是昂贵的。
目的是能够存储查询的“临时”实例,以便以后能够派生它们。也就是说,如果您有多个共享序列某些部分的查询,您应该能够执行类似的操作
\n\nq := gorm.Select(...).Limit(...).Order(...)\nq1 := q.Where(...)\nq2 := q.Where(...)\nRun Code Online (Sandbox Code Playgroud)\n\n(这个例子是一个粗略的例子,可能甚至没有映射到 GORM API,因为我自己不使用它。)
\n\n现在,我相信与执行 SQL 查询的成本相比,克隆内存中不会长时间保留的对象不会影响太多性能,这意味着网络往返\xe2\x80\xa6
\n| 归档时间: |
|
| 查看次数: |
2614 次 |
| 最近记录: |