如何在PostgreSQL中表示具有不确定性的日期
PostgreSQL提供了日期格式数据类型来存储日期.然而,这些日期的问题是 – 据我所知 – 他们不能提出不确定性的原因.
有时人们不知道某事的完整日期,但知道它发生在1995年1月或“1999年或2000年”(日期2).可能有几个原因: >人们不记得确切的日期; 我想知道是否有一种数据类型来存储这样的“日期”以及它们是如何传递的.它将导致某些操作的e值逻辑,例如date2< 20001/01/01应该是真的,date2< 2000/01/01是可能的,date2< 1998/01/01应该是假的. 如果没有这样的数据类型,那么在自己构建这样的“表”有什么好的做法?
有几种不同的方法来处理模糊日期.在PostgreSQL中,您可以使用
>一对日期列(earliest_possible_date,latest_possible_date), 范围数据类型是PostgreSQL的最新版本所特有的.您可以在任何SQL dbms中使用其他人. 您需要的那种模糊性取决于应用程序.查询模糊日期的方式取决于您选择的数据类型或结构.您需要牢牢掌握需要存储的模糊性以及用户需要回答的问题类型.您需要进行测试以确保您的数据库可以回答他们的问题. 例如,在法律制度中,日期可能会被记住很糟糕或污损.有人可能会说“这是2014年1月的某个星期四.我知道这是星期四,因为它是垃圾回收日”,或“这是去年6月或7月的第一周”.要记录那种模糊性,你需要另一张桌子. 或者邮戳可能会被破坏,因此您只能阅读“2014年14月”.你知道它在14号邮戳,但你不知道哪个月.同样,你需要另一张桌子. 除非你跳过一些箍,否则一些(全部?)这些都不会给你三值逻辑. (“可能”不是有效的布尔值.) (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- vb.net的异步读写数据流(使用线程、委托)
- Flex使用<mx:Tree>控件创建树(可添加和删除节点)
- postgresql – 如何在字符串的第n个位置查找字符
- [Unity3D]使用link.xml来控制strippinglevel减少dll库大小技
- SQLITE事务
- ruby-on-rails – RoR:named_scope,过去7天内创建的所有记
- Ruby:SSL_connect SYSCALL返回= 5 errno = 0 state =未知状
- ruby-on-rails – 在Cucumber场景中使用Rspec / Mocha存根
- C#将Json解析成DateTable的方法
- Oracle 11g新特性direct path read引发的系统停运故障诊断处