golang中 已知前端界面需要的json数据格式为 type Object3DJson struct { SceneID string `json:"sceneId" gorm:"primary_key"` Uuid string `json:"uuid" gorm:"index"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` } type ThreeSceneJson struct { SceneID string `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` } 使用gorm 映射的数据为: type Object3DDb struct { SceneID int64 `json:"sceneId" gorm:"primary_key"` Uuid int64 `json:"uuid" gorm:"index"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version int64 `json:"version"` } type ThreeSceneDb struct { SceneID int64 `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version int64 `json:"version"` } 如何以最高的效率实现转换和存储

时间: 2023-07-19 12:47:48 浏览: 150
您可以使用Golang中的标准库中的"encoding/json"包来进行JSON数据的解析和序列化。对于Gorm ORM,您可以使用它提供的结构体标记来指定表/列名和约束。下面是一种可能的实现方式: 1. 解析前端JSON数据 您可以使用"json.Unmarshal()"函数将前端JSON数据转换为Object3DJson或ThreeSceneJson类型的结构体对象。 2. 转换为Gorm模型对象 您可以将Object3DJson或ThreeSceneJson类型的对象转换为Object3DDb或ThreeSceneDb类型的Gorm模型对象,以便将其存储在数据库中。这可以通过创建一个新的Object3DDb或ThreeSceneDb类型的对象,并将其属性从前端JSON数据结构中复制而来来完成。您可以使用类型转换或手动属性复制等技术来实现此目的。 3. 存储到数据库 最后,您可以使用Gorm的"Create()"函数将Object3DDb或ThreeSceneDb类型的对象存储到数据库中。如果您需要更新现有记录,则可以使用"Save()"函数。 总的来说,这个过程可以在几个步骤中完成,但是要确保您的代码是高效的,您可以使用一些技巧来优化它,例如批量插入和更新。
相关问题

golang中 使用gin 和 gorm 框架实现: 已知前端界面需要的json数据格式为 type Object3DJson struct { SceneID string `json:"sceneId" gorm:"primary_key"` Uuid string `json:"uuid" gorm:"index"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` } type ThreeSceneJson struct { SceneID string `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` } 使用gorm 映射的数据为: type Object3DDb struct { SceneID int64 `json:"sceneId" gorm:"primary_key"` Uuid int64 `json:"uuid" gorm:"index"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version int64 `json:"version"` } type ThreeSceneDb struct { SceneID int64 `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version int64 `json:"version"` } 如何以最高的效率实现转换和存储。且业务上当更新Object3DDb 数据Version自增1,对应的Object3DDb SceneID 的ThreeSceneDb对应的Version也自增1。 当增删Object3DDb 时,对应的Object3DDb SceneID 的ThreeSceneDb对应的Version也自增1。 要求实现 Object3DJson,ThreeSceneJson 的增上改查 共计8个接口,其中Object3DJson 要求查询条件为 SceneID,且要求分页查询,ThreeSceneJson无需查询条件,直接返回全部。

为了实现最高效的转换和存储,可以使用以下步骤: 1. 将前端传来的 Object3DJson 和 ThreeSceneJson 数据转换为 Object3DDb 和 ThreeSceneDb 数据。 2. 在增加 Object3DDb 数据时,同时增加对应的 ThreeSceneDb 数据。在删除 Object3DDb 数据时,同时删除对应的 ThreeSceneDb 数据。 3. 在更新 Object3DDb 数据时,如果 Version 字段发生变化,同时更新对应的 ThreeSceneDb 数据的 Version 字段。 4. 对于查询 Object3DJson 数据,可以使用 gorm 的分页查询功能,根据 SceneID 字段进行查询并返回分页结果。 5. 对于查询 ThreeSceneJson 数据,直接查询数据库并返回所有数据即可。 以下是代码示例: ```go // Object3DJson 转 Object3DDb func object3DJsonToObject3DDb(object3DJson *Object3DJson) *Object3DDb { return &Object3DDb{ SceneID: strconv.Atoi(object3DJson.SceneID), Uuid: strconv.Atoi(object3DJson.Uuid), Type: object3DJson.Type, AdditionalData: object3DJson.AdditionalData, Version: strconv.Atoi(object3DJson.Version), } } // ThreeSceneJson 转 ThreeSceneDb func threeSceneJsonToThreeSceneDb(threeSceneJson *ThreeSceneJson) *ThreeSceneDb { return &ThreeSceneDb{ SceneID: strconv.Atoi(threeSceneJson.SceneID), Type: threeSceneJson.Type, AdditionalData: threeSceneJson.AdditionalData, Version: strconv.Atoi(threeSceneJson.Version), } } // 增加 Object3DDb 数据,同时增加对应的 ThreeSceneDb 数据 func addObject3DDb(object3DDb *Object3DDb) error { // 增加 Object3DDb 数据 if err := db.Create(object3DDb).Error; err != nil { return err } // 增加对应的 ThreeSceneDb 数据 threeSceneDb := &ThreeSceneDb{ SceneID: object3DDb.SceneID, Type: object3DDb.Type, Version: object3DDb.Version, } if err := db.Create(threeSceneDb).Error; err != nil { return err } return nil } // 删除 Object3DDb 数据,同时删除对应的 ThreeSceneDb 数据 func deleteObject3DDb(sceneID string) error { // 删除 Object3DDb 数据 if err := db.Where("scene_id = ?", sceneID).Delete(&Object3DDb{}).Error; err != nil { return err } // 删除对应的 ThreeSceneDb 数据 if err := db.Where("scene_id = ?", sceneID).Delete(&ThreeSceneDb{}).Error; err != nil { return err } return nil } // 更新 Object3DDb 数据,同时更新对应的 ThreeSceneDb 数据的 Version 字段 func updateObject3DDb(object3DDb *Object3DDb) error { // 更新 Object3DDb 数据 if err := db.Save(object3DDb).Error; err != nil { return err } // 更新对应的 ThreeSceneDb 数据的 Version 字段 if err := db.Model(&ThreeSceneDb{}).Where("scene_id = ?", object3DDb.SceneID).Update("version", object3DDb.Version).Error; err != nil { return err } return nil } // 查询 Object3DJson 数据,根据 SceneID 进行分页查询 func getObject3DJson(sceneID string, pageNum, pageSize int) ([]*Object3DJson, error) { var object3DDbList []*Object3DDb if err := db.Where("scene_id = ?", sceneID).Limit(pageSize).Offset((pageNum - 1) * pageSize).Find(&object3DDbList).Error; err != nil { return nil, err } object3DJsonList := make([]*Object3DJson, len(object3DDbList)) for i, object3DDb := range object3DDbList { object3DJsonList[i] = &Object3DJson{ SceneID: strconv.Itoa(object3DDb.SceneID), Uuid: strconv.Itoa(object3DDb.Uuid), Type: object3DDb.Type, AdditionalData: object3DDb.AdditionalData, Version: strconv.Itoa(object3DDb.Version), } } return object3DJsonList, nil } // 查询 ThreeSceneJson 数据,返回所有数据 func getThreeSceneJson() ([]*ThreeSceneJson, error) { var threeSceneDbList []*ThreeSceneDb if err := db.Find(&threeSceneDbList).Error; err != nil { return nil, err } threeSceneJsonList := make([]*ThreeSceneJson, len(threeSceneDbList)) for i, threeSceneDb := range threeSceneDbList { threeSceneJsonList[i] = &ThreeSceneJson{ SceneID: strconv.Itoa(threeSceneDb.SceneID), Type: threeSceneDb.Type, AdditionalData: threeSceneDb.AdditionalData, Version: strconv.Itoa(threeSceneDb.Version), } } return threeSceneJsonList, nil } ```

golang 使用gorm 将type ThreeScene struct { SceneID string `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` }增删改查 ,且要求SceneID 在数据库内为 int64

如果要使用 GORM 实现对 `ThreeScene` 结构体的增删改查操作,并且要求 `SceneID` 在数据库内为 `int64` 类型,可以按照以下步骤进行: 1. 安装 GORM: ```bash go get -u gorm.io/gorm ``` 2. 创建数据库连接: ```go import ( "gorm.io/driver/mysql" "gorm.io/gorm" ) func main() { dsn := "user:password@tcp(host:port)/db_name?charset=utf8mb4&parseTime=True&loc=Local" db, err := gorm.Open(mysql.Open(dsn), &gorm.Config{}) if err != nil { panic(err) } } ``` 其中,`user` 和 `password` 分别为数据库的用户名和密码,`host` 和 `port` 分别为数据库的地址和端口号,`db_name` 为数据库名称。 3. 定义 `ThreeScene` 结构体: ```go type ThreeScene struct { SceneID int64 `json:"sceneId" gorm:"primary_key"` Type int `json:"type"` AdditionalData string `json:"additionalData"` Version string `json:"version"` } ``` 注意,这里将 `SceneID` 的类型从 `string` 改为了 `int64`。 4. 创建表格: ```go func main() { // ... db.AutoMigrate(&ThreeScene{}) } ``` 这会自动在数据库中创建一个名为 `three_scenes` 的表格,其中包含 `SceneID`、`Type`、`AdditionalData` 和 `Version` 四个字段。 5. 插入数据: ```go func main() { // ... scene := ThreeScene{ SceneID: 1234567890, Type: 1, AdditionalData: "some additional data", Version: "1.0.0", } result := db.Create(&scene) if result.Error != nil { panic(result.Error) } } ``` 这会将一个新的 `ThreeScene` 对象插入到数据库中。 6. 查询数据: ```go func main() { // ... var scene ThreeScene result := db.First(&scene, "scene_id = ?", 1234567890) if result.Error != nil { if errors.Is(result.Error, gorm.ErrRecordNotFound) { fmt.Println("record not found") } else { panic(result.Error) } } else { fmt.Printf("%+v\n", scene) } } ``` 这会查询数据库中 `SceneID` 为 1234567890 的记录,并将结果保存在 `scene` 变量中。 7. 更新数据: ```go func main() { // ... result := db.Model(&ThreeScene{}).Where("scene_id = ?", 1234567890).Update("additional_data", "new additional data") if result.Error != nil { panic(result.Error) } } ``` 这会将 `SceneID` 为 1234567890 的记录的 `AdditionalData` 字段更新为 "new additional data"。 8. 删除数据: ```go func main() { // ... result := db.Delete(&ThreeScene{}, "scene_id = ?", 1234567890) if result.Error != nil { panic(result.Error) } } ``` 这会删除 `SceneID` 为 1234567890 的记录。 注意,在上面的示例代码中,我们使用了 GORM 的链式调用语法,这可以让我们更方便地构建 SQL 语句。同时,我们还使用了 `result.Error` 来检查操作是否成功,这可以避免出现一些难以排查的错误。
阅读全文

相关推荐

大家在看

recommend-type

MotorContral.rar_VC++ 电机控制_上位机_电机_电机 上位机_电机vc上位机

这是电机控制方面上位机程序,需要vc++6.0开发,对学习电机控制很有帮助.
recommend-type

一种基于STM32的智能交通信号灯设计的研究.rar

一种基于STM32的智能交通信号灯设计的研究.rar
recommend-type

中国AI安防行业:Ambarella业绩反映AI需求强劲.zip

中国AI安防行业:Ambarella业绩反映AI需求强劲
recommend-type

【答题卡识别】 Hough变换答题卡识别【含Matlab源码 250期】.zip

Matlab领域上传的代码均可运行,亲测可用,直接替换数据即可,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描博客文章底部QQ名片; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作 图像识别:表盘识别、车道线识别、车牌识别、答题卡识别、电器识别、跌倒检测、动物识别、发票识别、服装识别、汉字识别、红绿灯识别、火灾检测、疾病分类、交通标志牌识别、口罩识别、裂缝识别、目标跟踪、疲劳检测、身份证识别、人民币识别、数字字母识别、手势识别、树叶识别、水果分级、条形码识别、瑕疵检测、芯片识别、指纹识别
recommend-type

挖掘机叉车工程车辆检测数据集VOC+YOLO格式5067张7类别.7z

集格式:Pascal VOC格式+YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):5067 标注数量(xml文件个数):5067 标注数量(txt文件个数):5067 标注类别数:7 标注类别名称:[“ConcreteTruck”,“Excavator”,“Forklift”,“Loader”,“Steamroller”,“Truck”,“Worker”] 对应中文名:[“混凝土运输车”、“挖掘机”、“叉车”、“装载机”、“压路机”、”卡车“、”工人“] 更多信息:https://blog.csdn.net/FL1623863129/article/details/142093679

最新推荐

recommend-type

golang中为什么不存在三元运算符详解

在Golang中,你可能会发现一个与其他编程语言不同的特点,那就是它不支持三元运算符。三元运算符通常在其他语言如Python、JavaScript、C++等中被广泛使用,其语法形式为`条件表达式 ? 真值表达式 : 假值表达式`。...
recommend-type

Printer Queue算法(华为: 打印任务排序, POJ3125)Golang实现

这个问题涉及到ACM竞赛中的算法设计,它要求我们根据输入数据,确定打印任务的执行顺序,并计算特定任务的打印时间。 **问题描述:** 该问题的输入包括多个测试用例,每个测试用例由两行组成。第一行给出测试用例的...
recommend-type

Golang 使用map需要注意的几个点

【Golang 使用map需要注意的几个点】 在Golang中,`map`是一种非常重要的数据结构,它提供了一种通过键来查找对应值的方法。这里我们将详细介绍Golang中使用`map`需要注意的一些关键点。 1. **简介** - `map`是...
recommend-type

简单谈谈Golang中的字符串与字节数组

在Golang中,字符串是一种非常基础且常用的数据类型,它实际上是字符组成的只读字节数组。字符串在内存中以连续的方式存储,每个字符对应一个字节,这与C语言中的char数组类似。然而,与C不同的是,Golang中的字符串...
recommend-type

selenium中get_cookies()和add_cookie()的用法详解

在使用Selenium进行Web自动化测试或爬虫时,有时我们需要处理与用户登录相关的任务。这时,Selenium提供了方便的方法来管理浏览器的cookies。本文将详细讲解`get_cookies()`和`add_cookie()`这两个方法的用法。 `...
recommend-type

WildFly 8.x中Apache Camel结合REST和Swagger的演示

资源摘要信息:"CamelEE7RestSwagger:Camel on EE 7 with REST and Swagger Demo" 在深入分析这个资源之前,我们需要先了解几个关键的技术组件,它们是Apache Camel、WildFly、Java DSL、REST服务和Swagger。下面是这些知识点的详细解析: 1. Apache Camel框架: Apache Camel是一个开源的集成框架,它允许开发者采用企业集成模式(Enterprise Integration Patterns,EIP)来实现不同的系统、应用程序和语言之间的无缝集成。Camel基于路由和转换机制,提供了各种组件以支持不同类型的传输和协议,包括HTTP、JMS、TCP/IP等。 2. WildFly应用服务器: WildFly(以前称为JBoss AS)是一款开源的Java应用服务器,由Red Hat开发。它支持最新的Java EE(企业版Java)规范,是Java企业应用开发中的关键组件之一。WildFly提供了一个全面的Java EE平台,用于部署和管理企业级应用程序。 3. Java DSL(领域特定语言): Java DSL是一种专门针对特定领域设计的语言,它是用Java编写的小型语言,可以在Camel中用来定义路由规则。DSL可以提供更简单、更直观的语法来表达复杂的集成逻辑,它使开发者能够以一种更接近业务逻辑的方式来编写集成代码。 4. REST服务: REST(Representational State Transfer)是一种软件架构风格,用于网络上客户端和服务器之间的通信。在RESTful架构中,网络上的每个资源都被唯一标识,并且可以使用标准的HTTP方法(如GET、POST、PUT、DELETE等)进行操作。RESTful服务因其轻量级、易于理解和使用的特性,已经成为Web服务设计的主流风格。 5. Swagger: Swagger是一个开源的框架,它提供了一种标准的方式来设计、构建、记录和使用RESTful Web服务。Swagger允许开发者描述API的结构,这样就可以自动生成文档、客户端库和服务器存根。通过Swagger,可以清晰地了解API提供的功能和如何使用这些API,从而提高API的可用性和开发效率。 结合以上知识点,CamelEE7RestSwagger这个资源演示了如何在WildFly应用服务器上使用Apache Camel创建RESTful服务,并通过Swagger来记录和展示API信息。整个过程涉及以下几个技术步骤: - 首先,需要在WildFly上设置和配置Camel环境,确保Camel能够运行并且可以作为路由引擎来使用。 - 其次,通过Java DSL编写Camel路由,定义如何处理来自客户端的HTTP请求,并根据请求的不同执行相应的业务逻辑。 - 接下来,使用Swagger来记录和描述创建的REST API。这包括定义API的路径、支持的操作、请求参数和响应格式等。 - 最后,通过Swagger提供的工具生成API文档和客户端代码,以及服务器端的存根代码,从而使得开发者可以更加便捷地理解和使用这些RESTful服务。 这个资源的实践演示对于想要学习如何在Java EE平台上使用Camel集成框架,并且希望提供和记录REST服务的开发者来说是非常有价值的。通过这种方式,开发者可以更加快速和简单地创建和管理Web服务,同时也增强了API的可访问性和可维护性。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【声子晶体模拟全能指南】:20年经验技术大佬带你从入门到精通

![【声子晶体模拟全能指南】:20年经验技术大佬带你从入门到精通](https://docs.lammps.org/_images/lammps-gui-main.png) # 摘要 声子晶体作为一种具有周期性结构的材料,在声学隐身、微波和红外领域具有广泛的应用潜力。本文从基础理论出发,深入探讨了声子晶体的概念、物理模型和声子带结构的理论解析,同时介绍了声子晶体的数值模拟方法,包括有限元方法(FEM)、离散元方法(DEM)和分子动力学(MD)。本文还提供了一套完整的声子晶体模拟实践指南,涵盖了模拟前的准备工作、详细的模拟步骤以及结果验证和案例分析。此外,文章探讨了声子晶体模拟的高级技巧和拓展
recommend-type

2024-07-27怎么用python转换成农历日期

在Python中,可以使用`lunarcalendar`库来将公历日期转换为农历日期。首先,你需要安装这个库,可以通过pip命令进行安装: ```bash pip install lunarcalendar ``` 安装完成后,你可以使用以下代码将公历日期转换为农历日期: ```python from lunarcalendar import Converter, Solar, Lunar, DateNotExist # 创建一个公历日期对象 solar_date = Solar(2024, 7, 27) # 将公历日期转换为农历日期 try: lunar_date = Co
recommend-type

FDFS客户端Python库1.2.6版本发布

资源摘要信息:"FastDFS是一个开源的轻量级分布式文件系统,它对文件进行管理,功能包括文件存储、文件同步、文件访问等,适用于大规模文件存储和高并发访问场景。FastDFS为互联网应用量身定制,充分考虑了冗余备份、负载均衡、线性扩容等机制,保证系统的高可用性和扩展性。 FastDFS 架构包含两个主要的角色:Tracker Server 和 Storage Server。Tracker Server 作用是负载均衡和调度,它接受客户端的请求,为客户端提供文件访问的路径。Storage Server 作用是文件存储,一个 Storage Server 中可以有多个存储路径,文件可以存储在不同的路径上。FastDFS 通过 Tracker Server 和 Storage Server 的配合,可以完成文件上传、下载、删除等操作。 Python 客户端库 fdfs-client-py 是为了解决 FastDFS 文件系统在 Python 环境下的使用。fdfs-client-py 使用了 Thrift 协议,提供了文件上传、下载、删除、查询等接口,使得开发者可以更容易地利用 FastDFS 文件系统进行开发。fdfs-client-py 通常作为 Python 应用程序的一个依赖包进行安装。 针对提供的压缩包文件名 fdfs-client-py-master,这很可能是一个开源项目库的名称。根据文件名和标签“fdfs”,我们可以推测该压缩包包含的是 FastDFS 的 Python 客户端库的源代码文件。这些文件可以用于构建、修改以及扩展 fdfs-client-py 功能以满足特定需求。 由于“标题”和“描述”均与“fdfs-client-py-master1.2.6.zip”有关,没有提供其它具体的信息,因此无法从标题和描述中提取更多的知识点。而压缩包文件名称列表中只有一个文件“fdfs-client-py-master”,这表明我们目前讨论的资源摘要信息是基于对 FastDFS 的 Python 客户端库的一般性了解,而非基于具体文件内容的分析。 根据标签“fdfs”,我们可以深入探讨 FastDFS 相关的概念和技术细节,例如: - FastDFS 的分布式架构设计 - 文件上传下载机制 - 文件同步机制 - 元数据管理 - Tracker Server 的工作原理 - Storage Server 的工作原理 - 容错和数据恢复机制 - 系统的扩展性和弹性伸缩 在实际使用中,开发者可以通过 fdfs-client-py 库来与 FastDFS 文件系统进行交互,利用其提供的 API 接口实现文件的存储、管理等功能,从而开发出高效、可靠的文件处理应用。开发者可以根据项目的实际需求,选择合适的 FastDFS 版本,并根据官方文档进行安装、配置及优化,确保系统稳定运行。 总的来说,fdfs-client-py 是 FastDFS 文件系统与 Python 应用之间的一座桥梁,它使得开发者能够更加方便地将 FastDFS 集成到基于 Python 开发的应用中,发挥出 FastDFS 在文件管理方面的优势。"