Oracle中合理的年份数据类型是什么?
我想到了两种也许性: > NUMBER(4) 专业号码(4): >假如指定为UNIQUE,则无法复制条目 Con NUMBER(4): >无验证(譬喻负数) 专业日期: >验证 竣事日期: >可以一再输入(‘2013-06-24′,’2013-06-23’,…) 作为附加要求,该列与当前年份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. (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |