MyException - 我的异常网
当前位置:我的异常网» 数据库 » Oracle拾遗系列(1)

Oracle拾遗系列(1)

www.MyException.Cn  网友分享于:2013-01-01  浏览:0次
Oracle拾遗系列(一)

 

Oracle拾遗系列(一)

 

鉴于内容监管困难、赢利模式缺少、成本压力巨大,市面上大大小小的「网盘云盘」要么转型要么关停。为此,我的双十一购物车里已经躺了2个1T的硬盘(就等12点开抢了),Evernote也付费升级成了高级用户,就差没自建云服务了。一些网络服务特别是免费的服务,比如之前的google reader、yahoo mail、百度空间...都是说停就停,让你措手不及。今天翻了下之前发在百度空间里的好多文章,幸好还有「微信」这么优雅的产品,就随手搬一篇老文mark下。


1、关于oracle的add_months

先来看看下面这几个select语句的结果吧:

select add_months(to_date('2010-02-28','yyyy-mm-dd'),1) from dual;
ADD_MONTHS(TO_DATE('2010-02-28
------------------------------
2010-3-31

select add_months(to_date('2012-02-28','yyyy-mm-dd'),1) from dual;
ADD_MONTHS(TO_DATE('2010-02-28
------------------------------
2010-3-31

select add_months(to_date('2010-03-31','yyyy-mm-dd'),1) from dual;
ADD_MONTHS(TO_DATE('2010-03-31
------------------------------
2010-4-30

ADD_MONTHS returns the date d plus n months. The argument n can be any integer. If d is the last day of the month or if the resulting month has fewer days than the day component of d, then the result is the last day of the resulting month. Otherwise, the result has the same day component as d.

哦,原来ADD_MONTHS会先优先判断是否当月最后一天,如果是当月的最后一天,则结果为N月后的最后一天;如果不是,则为N月后的第D天。不过当N月后没有第D天的话(比如4月份没有31日),它也会把它置成最后一天。

2、关于oracle的not in

IN是一个成员条件, 对于给定的一个集合或者子查询,它会比较每一个成员值。 IN功能上相当于 =ANY 的操作,而NOT IN 功能上相当于 !=ALL 的操作。 IN在逻辑上实际上就是对给定的成员集合或者子查询结果集进行逐条的判定。

SELECT name FROM employee A WHERE A.name not in ('gallen','tomoya',NULL)

结果会是什么呢?结果是什么都没有,结果为空集。为什么呢? 其实上面的sql语句等价于:

SELECT name FROM employee A WHERE A.name!='gallen' AND A.name!='tomoya' AND A.name!=NULL

根据NULL的运算特性和真值表,该语句无论前两个判定条件是否为真,其结果一定是NULL或者FALSE。故绝对没有任何记录可以返回。

其实平时的时候并没有上面的语句那么明显,集合往往会是一个子查询,比如:

SELECT name FROM employee A WHERE A.name not in (select name FROM employee A WHERE A.salary>8000)

这时候,你要预先在子查询里把NULL去掉,比如用nvl。

3、Oracle修改字段的类型、精度、范围

可能修改字段的精度和范围比修改字段类型来得更常见,比如我们需要把某个字段的数据类型从原来的number(10)变为number(10,2)型的实际操作。要是没有数据的话直接用以下语句即可

alter table tbl_test modify cityCode number(10,2);

但是有数据的话就不能用上面方法了,为什么呢?因为oracle只允许在类型相同的情况下,增加精度或者放大范围,"column to be modified must be empty to decrease precision or scale" 。

有人会问number(10)变为number(10,2)精度不是变大了吗?其实不然,number()类型的默认精度是38位,你不指定精度,oracle无法辨别具体位数,所以无论是number(10)变为number(10,2)还是number(10,2)变为number(10),在该字段非空的情况下都是不允许的。

alter table tbl_test add cityCode_temp number(5,2)
update tbl_test set cityCode_temp=permile;
alter table tbl_test drop column cityCode;
alter table tbl_test rename column cityCode_temp to cityCode;

这种方法会使列名发生变化,而且字段顺序增加 有可能发生行迁移,对应用程序会产生影响 以下方法是比较好的方法 不用使列名发生变化 也不会发生表迁移,但这个有个缺点是表要更新两次 如果数据量较大的话 产生的undo和redo更多 ,前提也是要停机做 要是不停机的话 ,也可以采用在线重定义方式来做 以下是脚本:

alter table tbl_test add cityCode_temp number;
Add/modify columns
alter table tbl_test modify cityCode null;
update tbl_test set cityCode_temp=cityCode,cityCode=null;
commit;
alter table tbl_test modify cityCode number(10,2);
update tbl_test set cityCode=cityCode_temp,cityCode_temp=null;
commit;
alter table tbl_test drop column cityCode_temp;
alter table tbl_test modify cityCode not null;
select * from tbl_test ;

上述的相关内容就是对Oracle修改字段类型的方法的描述,希望会给你带来一些帮助在此方面。

4、未完待续...


欢迎关注我的个人微信公众号:能叔

能叔

文章评论

做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
老程序员的下场
老程序员的下场
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
中美印日四国程序员比较
中美印日四国程序员比较
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
编程语言是女人
编程语言是女人
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
程序员和编码员之间的区别
程序员和编码员之间的区别
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
代码女神横空出世
代码女神横空出世
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
如何成为一名黑客
如何成为一名黑客
漫画:程序员的工作
漫画:程序员的工作
鲜为人知的编程真相
鲜为人知的编程真相
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
那些争议最大的编程观点
那些争议最大的编程观点
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
Java程序员必看电影
Java程序员必看电影
一个程序员的时间管理
一个程序员的时间管理
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
程序员必看的十大电影
程序员必看的十大电影
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
程序员应该关注的一些事儿
程序员应该关注的一些事儿
 程序员的样子
程序员的样子
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员的鄙视链
程序员的鄙视链
总结2014中国互联网十大段子
总结2014中国互联网十大段子
程序员都该阅读的书
程序员都该阅读的书
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
10个调试和排错的小建议
10个调试和排错的小建议
Google伦敦新总部 犹如星级庄园
Google伦敦新总部 犹如星级庄园
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
2013年美国开发者薪资调查报告
2013年美国开发者薪资调查报告
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有