背景

在我们平时写接口的时候,避免不了这样一个问题,数据库中存的字段类型为datetime,代码中对应的实体类也是DateTime类型的字段,于是在读取数据库内容之后返回的数据也是DateTime类型的值,比如2022-10-24 18:34:56.110,但是对于服务器请求者来说,他们可能只需要显示年月日即可,后面的时分秒是不需要的,如果能说服他们,不用修改我们的代码,当日最好。那么对于我们服务提供者来说,如何处理这类问题呢?

实现方式1

可以直接把返回的实体类中的DateTime修改为string,格式就可以自定义了,但是缺点也很明显,

1.无法使用ToListMapTo等方式直接把数据库中读取的DateTime值直接转换成String
2.若有多个接口需要修改,比较麻烦。
3.适用情况单一,若有别的字段类型修改,比较麻烦。

实现方式2(推荐)

采用JsonConverterAttribute类和JsonConverter<T>类,通过给属性加特性类的方式进行修改。
实现的简要步骤如下。
这里我新建个一个ASP.NET Core Web API的项目,来做示范。项目建好之后内容如下。
WeatherForecastController.cs内容如下。

using Microsoft.AspNetCore.Mvc;namespace DateTime返回年月日.Controllers
{[ApiController][Route("[controller]")]public class WeatherForecastController : ControllerBase{private static readonly string[] Summaries = new[]{"Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"};private readonly ILogger<WeatherForecastController> _logger;public WeatherForecastController(ILogger<WeatherForecastController> logger){_logger = logger;}[HttpGet(Name = "GetWeatherForecast")]public IEnumerable<WeatherForecast> Get(){return Enumerable.Range(1, 5).Select(index => new WeatherForecast{Date = DateTime.Now.AddDays(index),TemperatureC = Random.Shared.Next(-20, 55),Summary = Summaries[Random.Shared.Next(Summaries.Length)]}).ToArray();}}
}

Get 接口中,返回了一个WeatherForecast的一个数组,在这个实体类中,有一个DateTime类型的字段Date,我们请求下接口看下返回值。

这里可以看到,Date字段返回的是一个包含年月日,并且还有时区的一个字符串。
WeatherForecast实体类如下

using System.Text.Json.Serialization;namespace DateTime返回年月日
{public class WeatherForecast{public DateTime Date { get; set; }public int TemperatureC { get; set; }public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);public string? Summary { get; set; }}
}

重点来了。参考https://docs.microsoft.com/zh-cn/dotnet/api/system.text.json.serialization.jsonconverterattribute?view=net-6.0

JsonConverterAttribute可用反射的方式指定一个转换器类。那么我们就新建一个名为DateOnlyConverter的类,继承JsonConverter<T>这个泛型类,其中需要指定类型为DateTime,内容如下。

using System.Text.Json;
using System.Text.Json.Serialization;namespace DateTime返回年月日
{public class DateOnlyConverter : JsonConverter<DateTime>{public override DateTime Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options){throw new NotImplementedException();}public override void Write(Utf8JsonWriter writer, DateTime value, JsonSerializerOptions options){writer.WriteStringValue(value.ToString("yyyy-MM-dd"));}}
}

JsonConverter<T>包含两个抽象接口必须添加对应的实现,ReadWrite,我们只需要修改具体的Write方法,实现内容也非常简单,就是把对应的类型进行转换。
最后在WeatherForecast类的Date属性上添加上对应的特性。

using System.Text.Json.Serialization;namespace DateTime返回年月日
{public class WeatherForecast{[JsonConverter(typeof(DateOnlyConverter))]public DateTime Date { get; set; }public int TemperatureC { get; set; }public int TemperatureF => 32 + (int)(TemperatureC / 0.5556);public string? Summary { get; set; }}
}

最后来看下调用结果吧。

通过添加特性的方式,不用修改实体类的类型,也不用修改具体的业务逻辑。

结语

参考内容:
https://docs.microsoft.com/zh-cn/dotnet/api/system.text.json.serialization.jsonconverter-1?view=net-6.0

have a wonderful day.

C# 接口中DateTime类型字段返回年月日格式,去掉时分秒的数据相关推荐

  1. datetime类型的取年月日 sql_SQL2005怎么截取datetime类型字段的年月日,并以截取后的(年月日)字段排序...

    在用php连接sql server查询时间字段时,首先是查询出来的时间是这种格式的 11 30 2009 10:20:20am 我打开sqlserver数据库查看表中的数据 却是2009-11-30 ...

  2. C# WebAPI中DateTime类型字段在使用微软自带的方法转json格式后默认含T的解决办法...

    C# WebAPI中DateTime类型字段在使用微软自带的方法转json格式后默认含T的解决办法 原文:C# WebAPI中DateTime类型字段在使用微软自带的方法转json格式后默认含T的解决 ...

  3. mysql数据库插入datetime_往MySQL数据库datetime类型字段中插入数据库的当前时间

    代码: StringBuilder sb = new StringBuilder(); sb.append(" insert into uosdetailfile ("); sb. ...

  4. Mysql在sql中截取时间类型字段的年月日和时间-DATE_FORMAT() 函数

    Mysql在sql中截取时间类型字段的年月日和时间 DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据. 下面的脚本使用 DATE_FORMAT() 函数来显示不同的格式.我们使用 N ...

  5. java date 不要时分秒_java 去掉Date类型 年月日 后面的时分秒

    因为用到这个东西了,随手查了下,发现解决方案有很多,作为一个菜鸟来说 有必要整理一下-.- 我用的是hibernate自己生成的表,所以util Date在mysql  只有年月日 而没有时分秒 然后 ...

  6. java calendar去掉时分秒_java 8:只取年月日的java.util.Date(时分秒清零)对象

    废弃的方法(@Deprecated) 如果不想要java.util.Date中的时分秒数据,希望将它清零,只保留年月日,最简单的办法是 调用setHours,setMinutes,setSeconds ...

  7. PLSQL 查询结果只显示年月日不显示时分秒的解决方法

    PLSQL 14查询结果只显示年月日不显示时分秒的解决方法 如果plsql里面日期显示出现混乱,并且按照一般的调整首选项里日期格式调整不了,可以修改环境变量,新建环境变量,变量名:nls_date_f ...

  8. 解决Entity Framework中DateTime类型字段异常

    从 datetime2 数据类型到 datetime 数据类型的转换产生一个超出范围的值 具体的错误原因是:C#中的DateTime类型比SqlServer中的datetime范围大.SqlServe ...

  9. mysql 默认时间字段 1067,mysql替datetime类型字段设置默认值default

    操作服务器环境为Linux centos5.7 安装的mysql版本 MariaDB,图简单直接使用命令install上去的. 在自己mac上测试数据库修改Alter语句没有问题的, ALTER TA ...

最新文章

  1. Blender全流程制作真实感3D产品学习教程
  2. 新来的同事问我 where 1=1 是什么意思
  3. JavaScript语言基础.上
  4. 新的信息论诞生前的若干问题分析
  5. 为什么需要DTO(数据传输对象)
  6. RTMP Handshake
  7. 简明Python3教程 16.标准库
  8. js中prototype用法
  9. 十大PHP程序员必备工具
  10. 同时大量连接导致的DDOS攻击,导致收发器宕机,用户大面积超时掉线
  11. 201671030119 词频统计软件项目报告
  12. linux下ps ef命令详解,linux中ps -ef命令
  13. 新电脑如何分盘---傻瓜式教学
  14. 没文化 真可怕!【新汉语字典小程序】来拯救你!
  15. 买面茶--郭德纲相声
  16. Linux 文件系统原理 / 虚拟文件系统VFS
  17. 5.10 自定义颜色至色板和全局色的使用 [Illustrator CC教程]
  18. 全新版的TFN 光时域反射仪上线了,大家一块了解一下吧。
  19. 启用Windows沙盒
  20. 图卷积神经网络4-空域卷积:空域卷积局限性分析和过平滑解决方案

热门文章

  1. 常见的浏览器兼容性问题总结(有自己遇到的还有网上大神总结的)
  2. Visual Studio 2017-2019版本创建C#项目时没有创建网站这一选项?
  3. 年轻女孩都超喜欢的美白祛斑秘方
  4. 机器人学习--基于3D激光雷达数据的MCL全局定位
  5. Python实例:网络爬虫抓取豆瓣3万本书(5)
  6. ubuntu 16.04 LTS flash player播放器插件安装方法
  7. 服务器自签名证书过期可以,解决docker的tls(ssl)证书过期问题
  8. python提前结束本层循环_python中退出多层循环的方法
  9. c++实现split函数
  10. 证券行业信息化9-研究发展部做些什么工作?CFA是什么?研究报告是如何得到IT应用的支持的?