改进代码func TracingList(ctx *gin.Context) { resp := models.Response{ Code: 0, Msg: "success", } t, _ := strconv.Atoi(ctx.Query("t")) label, _ := strconv.Atoi(ctx.Query("label")) page, _ := strconv.Atoi(ctx.DefaultQuery("page", "1")) pageSize, _ := strconv.Atoi(ctx.DefaultQuery("pageSize", "10")) code := ctx.Query("code") //设施类型 if len(code) == 0 { resp.Code = 400 resp.Msg = "请输入code值" ctx.JSON(400, resp) return } type Total struct { gorm.Model Type int16 Source int16 Explanation string Label int16 FacilityID string } db := common.DB.Session(&gorm.Session{}) if t < 0 || t > 5 { var req interface{} switch t { case 0: req = []*Total{} case 1: req = []*models.Flaw{} case 2: req = []*models.Issue{} case 3: req = []*models.Record{} case 4: req = []*models.Quality{} case 5: req = []*models.Inspection{} } //查询并分页 if t < 1 || t > 5 { res := db.Scopes(models.Paginate(page, pageSize)).Where("facility_id=?", code).Find(&req) if res.RowsAffected == 0 { resp.Code = 400 resp.Msg = "记录不存在" ctx.JSON(400, resp) return } } else { res := db.Scopes(models.Paginate(page, pageSize)).Raw("SELECT * FROM flaws WHERE facility_id = ? "+ "UNION SELECT * FROM issues WHERE facility_id = ? "+ "UNION SELECT * FROM records WHERE facility_id = ? "+ "UNION SELECT * FROM qualities WHERE facility_id = ? "+ "UNION SELECT * FROM inspections WHERE facility_id = ?", "code", "code", "code", "code", "code").Find(&req) if res.RowsAffected == 0 { resp.Code = 400 resp.Msg = "记录不存在" ctx.JSON(400, resp) return } } resp.Data = req ctx.JSON(200, resp) } else if label < 1 || label > 4 { var req []*Total res := db.Scopes(models.Paginate(page, pageSize)).Raw("SELECT * FROM flaws WHERE label = ? "+ "UNION SELECT * FROM issues WHERE label = ? "+ "UNION SELECT * FROM records WHERE label = ? "+ "UNION SELECT * FROM qualities WHERE label = ? "+ "UNION SELECT * FROM inspections WHERE label = ?", "label", "label", "label", "label", "label").Find(&req) if res.RowsAffected == 0 { resp.Code = 400 resp.Msg = "记录不存在" ctx.JSON(400, resp) return } resp.Data = req ctx.JSON(200, resp) } else { ctx.JSON(400, models.Response{ Code: 400, Msg: "参数有误", }) return } }

时间: 2024-01-09 20:04:04 浏览: 33
以下是改进的代码: ```go func TracingList(ctx *gin.Context) { resp := models.Response{ Code: 0, Msg: "success", } code := ctx.Query("code") if len(code) == 0 { resp.Code = 400 resp.Msg = "请输入code值" ctx.JSON(400, resp) return } t, err := strconv.Atoi(ctx.Query("t")) if err != nil || t < 0 || t > 5 { resp.Code = 400 resp.Msg = "无效的参数t" ctx.JSON(400, resp) return } label, err := strconv.Atoi(ctx.Query("label")) if err != nil || label < 1 || label > 4 { resp.Code = 400 resp.Msg = "无效的参数label" ctx.JSON(400, resp) return } page, err := strconv.Atoi(ctx.DefaultQuery("page", "1")) if err != nil || page < 1 { resp.Code = 400 resp.Msg = "无效的参数page" ctx.JSON(400, resp) return } pageSize, err := strconv.Atoi(ctx.DefaultQuery("pageSize", "10")) if err != nil || pageSize < 1 { resp.Code = 400 resp.Msg = "无效的参数pageSize" ctx.JSON(400, resp) return } var req interface{} switch t { case 0: req = []*Total{} case 1: req = []*models.Flaw{} case 2: req = []*models.Issue{} case 3: req = []*models.Record{} case 4: req = []*models.Quality{} case 5: req = []*models.Inspection{} } db := common.DB.Session(&gorm.Session{}) res := db.Scopes(models.Paginate(page, pageSize)).Where("facility_id=?", code) if t >= 1 && t <= 5 { res = res.Table("flaws").Where("facility_id=?", code). Or("facility_id=?", code). Or("facility_id=?", code). Or("facility_id=?", code). Or("facility_id=?", code) } res.Find(req) if res.RowsAffected == 0 { resp.Code = 400 resp.Msg = "记录不存在" ctx.JSON(400, resp) return } resp.Data = req ctx.JSON(200, resp) } ``` 主要改进包括: 1. 对输入的参数进行了有效性检查,如 t、label、page 和 pageSize 都需要为正整数,code 不能为空。 2. 使用了 Go 语言内置的错误处理机制,当参数无效时,返回错误信息。 3. 将 SQL 查询语句拆分为两段,根据 t 的值判断使用哪一段,避免了使用 Raw() 方法的安全隐患。 4. 代码结构更加清晰,易于阅读和维护。

相关推荐

怎么精简代码func BasinTree(id string) ([]*models.Basin, error) { var basins []*models.Basin res := common.DB.Where("watershed_id = ?", id).Find(&basins) for _, item := range basins { if res.RowsAffected > 0 { //查询流域内所有河道 var subrivers []*models.SubRiver var rivers models.PsRiver common.DB.Model(&rivers).Where("watershed_id = ?", item.ID).Find(&subrivers) item.SubRivers = subrivers var totalL float64 common.DB.Table("ps_rivers").Select("COALESCE(sum(segment_length), 0)").Where("watershed_id = ?", item.ID).Scan(&totalL) item.TotalLength = totalL //查询流域内所有湖泊 var sublakes []*models.SubLake var lakes models.PsLake common.DB.Model(&lakes).Where("watershed_id = ?", item.ID).Find(&sublakes) var totalA float64 common.DB.Table("ps_lakes").Select("COALESCE(sum(area),0)").Where("watershed_id = ?", item.ID).Scan(&totalA) item.TotalArea = totalA item.SubLakes = sublakes } } for _, item := range basins { if res.RowsAffected > 0 { id = strconv.FormatUint(uint64(item.ID), 10) item.SubBasins, _ = BasinTree(id) for _, v := range item.SubBasins { item.TotalArea = item.TotalArea + v.TotalArea item.TotalLength = item.TotalLength + v.TotalLength } if len(item.SubBasins) == 0 { return nil, nil } } } return basins, nil } func BasinInfo(ctx *gin.Context) { id := ctx.Query("id") var req models.Basin var err error resp := models.Response{ Code: 0, Msg: "success", } if len(id) == 0 { resp.Code = 400 resp.Msg = "请输入id值" ctx.JSON(400, resp) return } res := common.DB.Where("id = ?", id).Take(&req) if res.Error != nil { resp.Code = 400 resp.Msg = "查询失败" resp.Data = res.Error ctx.JSON(400, resp) return } //查询流域内所有河道 var subrivers []*models.SubRiver var rivers models.PsRiver var totalL float64 common.DB.Model(&rivers).Where("watershed_id = ?", id).Find(&subrivers) common.DB.Table("ps_rivers").Select("COALESCE(sum(segment_length), 0)").Where("watershed_id = ?", id).Scan(&totalL) req.SubRivers = subrivers req.TotalLength = totalL //查询流域内所有湖泊 var sublakes []*models.SubLake var lakes models.PsLake var totalA float64 common.DB.Model(&lakes).Where("watershed_id = ?", id).Find(&sublakes) common.DB.Table("ps_lakes").Select("COALESCE(sum(area),0)").Where("watershed_id = ?", id).Scan(&totalA) req.SubLakes = sublakes req.TotalArea = totalA req.SubBasins, err = BasinTree(id) if err != nil { resp.Code = 500 resp.Msg = "创建树失败" resp.Data = err ctx.JSON(500, resp) return } for _, v := range req.SubBasins { req.TotalArea = req.TotalArea + v.TotalArea req.TotalLength = req.TotalLength + v.TotalLength } resp.Data = req ctx.JSON(200, resp) }

最新推荐

recommend-type

操作系统实验二进程同步与互斥.docx

操作系统实验二进程同步与互斥
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

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

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

MATLAB结构体与数据库交互:无缝连接数据存储与处理,实现数据管理自动化

![MATLAB结构体与数据库交互:无缝连接数据存储与处理,实现数据管理自动化](https://ww2.mathworks.cn/products/database/_jcr_content/mainParsys/band_1749659463_copy/mainParsys/columns_copy/6d5289a2-72ce-42a8-a475-d130cbebee2e/image_copy_2009912310.adapt.full.medium.jpg/1709291769739.jpg) # 1. MATLAB结构体与数据库交互概述** MATLAB结构体与数据库交互是一种强大的
recommend-type

Link your Unity

project to C# script in Visual Studio. Can you provide me with some guidance on this? Yes, I can definitely help you with that! To link your Unity project to C# script in Visual Studio, you first need to make sure that you have both Unity and Visual Studio installed on your computer. Then, you can
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。