有关在.Net Core中以TEXT类型将Json格式字段存到数据库的学习

导言

 在写个值日接口时发现值日表中的值日时段是可以分多段的,想了想可以使用Json类型来存,不过之前没接触过在后端操作Json格式存到数据库的情况,之后学也了解到了一下方法来实现,故记录一下。

过程

     从前端到后端再到数据库的 JSON 字段传递过程通常涉及以下几个步骤:前端发送 JSON 数据,后端接受并处理,最终将数据存储到数据库。我们可以通过DTO限制前端传回的字段。

1. 前端发送 JSON 数据

假设前端使用的是 JSON 格式的数据,可以通过 POST 请求将数据发送到后端的 API。通常,这些数据通过一个表单或 AJAX 请求来提交。

2. 后端接收 JSON 数据(DTO)

后端通过控制器接收来自前端的 JSON 数据。在 ASP.NET Core 中,通常会定义一个 DTO(Data Transfer Object)类来接受和限制前端传入的字段。假设我们有一个 DutyDto 来定义允许前端传入的字段。

DTO 类:

/// <summary>
/// 值日创建Dto
/// </summary>
public class DutyCreateDto
{.../// <summary>/// 值日时段/// </summary>[Display(Name = "值日时段")][Required(ErrorMessage = "请设置值日时段/正确格式")][JsonProperty("dutyInPeriods")]public List<DutyPeriodDto> DutyInPeriods { get; set; }...
}/// <summary>/// 值日时段/// </summary>public class DutyPeriodDto{/// <summary>/// 描述:值日时间/// 空值:False/// 默认:/// </summary>[Display(Name = "值日时间")][SugarColumn(IsPrimaryKey = true)]public int DutyTime { get; set; }/// <summary>/// 描述 : 开始时间/// 空值 : True/// 默认 : /// </summary>[Display(Name = "开始时间")]public DateTime StartTime { get; set; }/// <summary>/// 描述 : 结束时间/// 空值 : True/// 默认 : /// </summary>[Display(Name = "结束时间")]public DateTime EndTime { get; set; }}
swagger接口测试大概长这样:

3.接收数据的 API 控制器:将DTO映射为对应实体

/// <summary>
/// 新增值日
/// </summary>
/// <param name="parm"></param>
/// <param name="DeptID"></param>
/// <returns></returns>
[HttpPost]
[Authorization(Power = "PRIV_DUTY_CREATE")]
public IActionResult Create([FromBody] DutyCreateDto parm,string DeptID)
{...var duty = parm.Adapt<Base_Duty>().ToCreate(_tokenManager.GetSessionInfo());// 使用 JSON 序列化将 Period 列表转换为字符串duty.DutyInPeriods = JsonConvert.SerializeObject(parm.DutyInPeriods);//插入值日表var respose = _dutyService.Add(duty);...}

4. 数据库中的 JSON 存储

在数据库中,JSON 数据通常存储为 TEXTJSON 类型(取决于数据库的支持),注意不要用varchar来存,因为varchar能存的字符很少,如果单条数据的json数据过大的话会报错。

 

5. 从数据库读取 JSON 数据

说是json其实真正存的还是字符串类型所以正常拿就行。不过要把string类型再反序列变成json类型

//从数据库拿到数据var signIn = _signInService.GetId(parm.SignInID); // 将JSON字符串反序列化为List<SignInPeriods>对象列表var signInPeriodsList = JsonConvert.DeserializeObject<List<SignInPeriodsDto>>(signIn.SignInPeriods);//之后当List<SignInPeriodsDto>用就行
//...

数据库存json方式:JSON和TEXT的比较

JSON:

优点:
  • 结构化存储:数据库会验证 JSON 格式的正确性,并确保存储的数据是有效的 JSON。
  • 高效查询:数据库提供对 JSON 字段的内置操作,可以直接在 SQL 查询中对 JSON 数据进行查询、筛选、修改。例如,查询 JSON 中的某个键值,或者使用 JSON 函数提取嵌套数据。
  • 索引支持:有些数据库支持对 JSON 字段的键值进行索引,从而提升查询性能。
使用场景:
  • 需要频繁对 JSON 数据进行查询和操作时。
  • 需要验证和保持 JSON 数据的完整性和格式一致性。
  • 需要数据库层面对 JSON 数据进行优化和索引。

TEXT:

优点:
  • 兼容性高:适用于那些不支持原生 JSON 类型的数据库(如较老版本的数据库)。
  • 简单存储:如果你不需要对 JSON 数据进行复杂的数据库操作,只需要保存和读取 JSON,这种方式可以满足需求。
缺点:
  • 无法验证数据:数据库无法验证存储的数据是否是有效的 JSON 格式。
  • 查询和操作不方便:如果需要在 SQL 中操作 JSON 字符串,必须手动解析 JSON,不能利用数据库的 JSON 函数。
  • 性能较差:查询和操作 JSON 数据时,性能不如使用 JSON 类型。

这里我用了TEXT

总结

  1. 前端到后端的 JSON 传递:前端通过 POST 请求发送 JSON 数据,后端通过 DTO 接收和限制字段。
  2. DTO 到实体映射:后端将 DTO 数据映射为实体,并通过 JsonConvert.SerializeObject 将 JSON 数据存储为字符串。
  3. 数据库中的 JSON 存储:数据库将 JSON 数据存储在 JSONTEXT 类型字段中。
  4. 从数据库读取 JSON:从数据库读取 JSON 字符串时,使用 JsonConvert.DeserializeObject 反序列化为 C# 对象。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/149095.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

千亿大数据平台——MySQL大数据优化

一、自增量的作用 1. 唯一性标识 - 为表中的每一行数据提供一个唯一的、自动生成的标识符&#xff0c;确保数据的唯一性和准确性。 2. 简化数据关联 - 在多个表之间进行关联操作时&#xff0c;自增量字段可以作为便捷的关联键&#xff0c;方便建立和维护表之间的关系…

C#和数据库高级:虚方法

文章目录 一、抽象方法和抽象类中的思考1.1、回顾抽象方法的特点1.2、针对抽象方法问题的引出 二、虚方法的使用步骤2.1、虚方法重写方法的调用2.2、系统自带的虚方法2.3、重写Equals方法2.4、虚方法和抽象方法的比较 三、虚方法和抽象方法的联系3.1、ToString()方法的应用 一、…

字母与符号检测系统源码分享

字母与符号检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer V…

ChatGLM-6B-部署与使用

✨ Blog’s 主页: 白乐天_ξ( ✿&#xff1e;◡❛) &#x1f308; 个人Motto&#xff1a;他强任他强&#xff0c;清风拂山冈&#xff01; &#x1f4ab; 欢迎来到我的学习笔记&#xff01; 什么是ChatGLM-6B 一、简介 ChatGLM-6B 是由清华大学知识工程实验室&#xff08;KEG&…

Python:百度贴吧实现自动化签到

早知道&#xff0c;还是python。 Github项目仓库在这。 相关API 签到贴吧列表 签到分为两个接口&#xff0c;PC端签到一次经验2&#xff0c;而移动端签到则是一次经验6。该用哪个接口已经很明显了。不过这里还是列出PC端的签到API。 # PC端签到接口 # sign_url "https:…

时序预测 | Python实现KAN+LSTM时间序列预测

时序预测 | Python实现KAN+LSTM时间序列预测 目录 时序预测 | Python实现KAN+LSTM时间序列预测预测效果基本介绍程序设计预测效果 基本介绍 时序预测 | KAN+LSTM时间序列预测(Python) KAN作为这两年最新提出的机制,目前很少人用,很适合作为时间序列预测的创新点,可以结合…

python全栈开发《37.列表(元组)的count函数》

元组的count函数的功能和用法与列表的count函数完全一致。 1.count的功能 返回当前列表中某个成员的个数。 2.count的用法 fruits [苹果,西瓜,水蜜桃,西瓜,雪梨] count fruits.count(西瓜) print(count) 运行结果&#xff1a; 2 注意&#xff1a;列表的内置函数count拿到需要…

【读书笔记-《30天自制操作系统》-24】Day25

本篇内容也比较简单。首先开发了蜂鸣器的API&#xff0c;然后增加更多的颜色显示。为了同时运行两个应用程序&#xff0c;又增加了一个命令行窗口。 1. 蜂鸣器 首先是增加蜂鸣器的功能。 蜂鸣器与定时器一样&#xff0c;是由PIT控制的。 蜂鸣器发声的控制&#xff1a; 音高…

Linux:Bash中的文件描述符详解

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 Linux中的所有进程&#xff0c;都拥有自己的文件描述符(File Descriptor, FD)&#xff0c;它是操作系统在管理进程和文件时的一种抽象概念。每个文件描述符由一个非负整…

开关电源自动测试系统的测试设备与特色

突破传统测试系统的操作维护困难等限制&#xff0c;NSAT-8000开关电源自动测试系统以其开放式架构和0代码模式&#xff0c;带来了不一样的开关电源自动化测试体验。 开关电源自动测试系统的测试设备 开关电源自动测试系统核心硬件包括&#xff1a;可编程交直流电源、电子负载、…

使用 HFD 加快 Hugging Face 模型和数据集的下载,解决443报错

Hugging Face 提供了丰富的预训练模型和数据集&#xff0c;而且使用 Hugging Face 提供的 from_pretrained() 方法可以轻松加载它们&#xff0c;但是&#xff0c;模型和数据集文件通常体积庞大&#xff0c;用默认方法下载起来非常花时间。 本文将指导你如何使用 HFD&#xff08…

小新 Pro13 + windows 11 家庭中文版(网络适配器及地址配置)

网络适配器位置及地址配置 网络适配器简介 计算机系统&#xff1a;网络适配器详解&#xff0c;全面剖析 网络适配器位置 不同于win11之前的版本&#xff0c;win11的网络适配器的位置如下&#xff1a; 1、右键 右下角的网络图标-》网络和internet设置-》高级网络设置-》可以…

冒泡排序bubble sort

冒泡排序&#xff08;bubble sort&#xff09;通过连续地比较与交换相邻元素实现排序。这个过程就像气泡从底部升到顶部一样&#xff0c;因此得名冒泡排序。 算法流程 def bubble_sort(nums: list[int]):"""冒泡排序"""n len(nums)# 外循环&…

46.哀家要长脑子了!

1.435. 无重叠区间 - 力扣&#xff08;LeetCode&#xff09; 方法一&#xff1a;动态规划 实际上本质就是找最长的无重叠子序列&#xff0c;那么我们可以遍历这个区间的集合&#xff0c;只要前一个区间的右端点是小于等于后一个区间的左端点&#xff0c;那么这两个区间就不是重…

如何将Excel表格嵌入Web网页在线预览、编辑并保存到自己服务器上?

猿大师办公助手作为一款专业级的网页编辑Office方案&#xff0c;不仅可以把微软Office、金山WPS和永中Office的Word文档内嵌到浏览器网页中实现在线预览、编辑保存等操作&#xff0c;还可以把微软Office、金山WPS和永中Office的Excel表格实现网页中在线预览、编辑并保存到服务器…

虚拟机:4、配置12.5的cuda和gromacs

前言&#xff1a;本机环境是win11&#xff0c;通过wsl2安装了ubuntu实例并已实现gpu直通&#xff0c;现在需要下载12.5的cuda 一、查看是否有gpu和合适的cuda版本 在ubuntu实例中输入 nvidia-smi输出如下&#xff1a; 说明该实例上存在gpu驱动&#xff0c;且适合的CUDA版本…

硬件测试(五):信号补偿

一、简介 高速信号的趋肤效应以及传输线的介质损耗&#xff0c;使信号在传输过程中衰减很大&#xff0c;导致最后得到的信号失真。为了在接收终端能得到比较好的波形&#xff0c;就需要对受损的信号进行补偿&#xff0c;常用的补偿技术有&#xff1a;预加重、去加重和均衡三种信…

思科安全网络解决方案

《网安面试指南》http://mp.weixin.qq.com/s?__bizMzkwNjY1Mzc0Nw&mid2247484339&idx1&sn356300f169de74e7a778b04bfbbbd0ab&chksmc0e47aeff793f3f9a5f7abcfa57695e8944e52bca2de2c7a3eb1aecb3c1e6b9cb6abe509d51f&scene21#wechat_redirect 《Java代码审…

告别xx搜索,我用这个AI工具...

点击“终码一生”&#xff0c;关注&#xff0c;置顶公众号 每日技术干货&#xff0c;第一时间送达&#xff01; 前段时间&#xff0c;逛 GitHub 的时候发现了一个评估报告&#xff0c;对AI搜索引擎进行了详细的准确性测试&#xff0c;覆盖6种主流语言和5类场景。 其中&#xf…

苍穹外卖上半部分总结

苍穹外卖一个很经典的项目 虽然已经烂大街&#xff0c;但项目依旧是很优秀&#xff0c;并且代码十分规范&#xff0c;很值得学习。 前置介绍 niginx反向代理 前端和后端的url请求不一致的原因&#xff1a;前端是请求到nginx服务器&#xff0c;再由nginx服务器转发到后端 ngi…