Oracle中合理的年份数据类型是什么?

Oracle中合理的年份数据类型是什么?,第1张

概述我想到了两种可能性: > NUMBER(4) >日期 专业号码(4): >如果指定为UNIQUE,则无法复制条目 >简单算术(加1,减1) Con NUMBER(4): >无验证(例如负数) 专业日期: >验证 结束日期: >可以重复输入(‘2013-06-24′,’2013-06-23’,…) >算术不那么容易(加1 = ADD_MONTHS(12)) 作为附加要求,该列与当前年份EXTRACT 我想到了两种可能性:

> NUMBER(4)
>日期

专业号码(4):

>如果指定为UNIQUE,则无法复制条目
>简单算术(加1,减1)

Con NUMBER(4):

>无验证(例如负数)

专业日期:

>验证

结束日期:

>可以重复输入(‘2013-06-24′,’2013-06-23’,…)
>算术不那么容易(加1 = ADD_MONTHS(12))

作为附加要求,该列与当前年份EXTRACT(YEAR FROM SYSDATE)进行比较.在我看来,NUMBER(4)是更好的选择.您怎么看?我错过了另一种选择吗?

解决方法 如果您愿意,可以使用基于函数的索引将日期列限制为每年只有一个条目:

create unique index uq_yr on <table> (trunc(<column>,'YYYY'));

试图在同一年插入两个日期会给你一个ORA-00001错误.当然,如果您不想要剩下的日期,那么持有它可能是无益的或令人困惑的,但另一方面,您可能希望保留次要信息(例如,如果您正在记录年度审计发生了,持有完整日期可能不会伤害任何事情).您也可以拥有一个虚拟列(来自11g),它可以保存trunc值以便于 *** 作.

您还可以使用间隔年(4)到月份数据类型,并使用numtoyminterval(2013,’year’)等插入.您可以使用区间运算来添加和减去年份,并提取以将年份作为数.总的来说,这可能比使用约会更痛苦.

如果你真的只对这一年感兴趣(并且你没有把这个月保持在不同的列!)那么一个数字可能是最简单的,有一个检查约束以确保它是一个合理的数字 – 数字(4)当你的意思是2,013时,并不会阻止你插入2.013(虽然你需要从一个字符串转换为命中,并且没有NLS参数不匹配),这将被截断为2.

总结

以上是内存溢出为你收集整理的Oracle中合理的年份数据类型是什么?全部内容,希望文章能够帮你解决Oracle中合理的年份数据类型是什么?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1157067.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存