gpt4 book ai didi

c# - PostgreSQL 不保存完整的 DateTimeOffset

转载 作者:行者123 更新时间:2023-11-29 11:45:12 24 4
gpt4 key购买 nike

我遇到了 PostgreSQL 或 Devart 数据库连接库的错误。以下是我创建的一个简单的测试应用程序:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace DateTimeOffsetTest
{
class Program
{
static void Main(string[] args)
{
using (var context = new Context())
{
var e = new Ent() { CreatedOn = DateTimeOffset.Now };
Console.WriteLine(e.CreatedOn.UtcDateTime.Ticks);
context.Ents.Add(e);
context.SaveChanges();
}

using (var context = new Context())
{
var ent = context.Ents.Single();

Console.WriteLine(ent.CreatedOn.UtcDateTime.Ticks);
Console.Read();

context.Ents.Remove(ent);
context.SaveChanges();
}
}
}
}

我希望写入控制台的两行是相同的,但第二行的最后一位数字始终为 0。示例:

Test output

这是 PostgreSQL 设置方式的精度问题吗?如果是,我能以某种方式改变它吗?如果我使用 SqlServer 作为我的数据库,这个测试工作正常。

最佳答案

如果 CreatedOn 是 PostgreSQL 时间戳,则精度为 1 微秒。 1 个刻度为 0.1 微秒。

关于c# - PostgreSQL 不保存完整的 DateTimeOffset,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31189006/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com