`
tomoya
  • 浏览: 1832 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

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、未完待续...


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

能叔

分享到:
评论

相关推荐

    ORACLE SQL性能优化系列

    ORACLE SQL性能优化系列 ORACLE SQL性能优化是数据库管理员和开发者非常关心的一个话题。为了提高数据库的性能,ORACLE 提供了多种优化技术。下面我们将详细介绍 ORACLE SQL 性能优化系列中的一些重要知识点。 一...

    oracle ebs系列帮助文档

    具体到文件名"oracle ebs系列",我们可以推测这可能是一个包含多个子主题的文档集合,覆盖了Oracle EBS的多个模块。例如,可能会有专门针对财务模块的文档,详细讲解如何进行账务处理、预算控制、报表生成等;供应链...

    oracle培训系列2

    本"Oracle培训系列2"主要关注的是Oracle数据库的基础到精通,特别是安装篇,旨在提供一个全面而详尽的Oracle安装教程,适用于各种操作系统平台。 在Oracle的安装过程中,有以下几个关键步骤和技术要点: 1. **...

    达内内部oracle系列教程

    达内的内部Oracle系列教程,是针对这一核心IT技术进行深入讲解的宝贵资源,旨在帮助学习者掌握Oracle的精髓,提升数据库管理和编程技能。 一、Oracle数据库基础 Oracle数据库系统的基础包括数据模型、数据库结构和...

    Oracle DSI学生手册

    DSI3是Oracle 8系列的, DSI4是Oracle 9系列的. 这样的文档上通常都印着:Oracle Confidential:For internal Use Only. DSI301 Advanced Server Support Skills DSI302 Data Management DSI303 Database Backup ...

    oracle系列培训教程

    【Oracle系列培训教程】是一个全面介绍Oracle数据库管理的资源集合,涵盖了从基础知识到高级操作的多个方面。这个压缩包中的文件分别围绕Oracle的安装配置、逻辑结构、性能优化、体系结构、备份与恢复以及数据库管理...

    IBM-ETP-Oracle01第一章 ORACLE数据库介绍

    首先,Oracle数据库是一个基于SQL标准的关系数据库,它提供了数据存储、管理、检索以及安全性等一系列功能。在本章节中,你将学习到如何创建数据库实例、表空间、数据库用户及权限管理。Oracle使用数据块、区、表...

    Oracle批处理:使用C# 自带Oracle驱动一次执行多条Sql语句

    本文将深入探讨如何在C#中利用Oracle自带的驱动来实现批处理,以一次执行多条SQL语句。 首先,我们需要了解Oracle的数据驱动,即ODP.NET(Oracle Data Provider for .NET)。这是Oracle公司为.NET开发者提供的一个...

    一段无需安装Oracle客户端即可访问Oracle数据库的delphi控件

    ODAC包括一系列的对象,如TOraSession、TOraQuery、TOraTable等,它们对应于Oracle的DBMS对象,如数据库会话、SQL查询和数据表。通过这些组件,开发者可以轻松地执行SQL语句、处理结果集、进行事务操作等。 使用...

    navicat链接oracle文件,OCI文件 oracle12版本 OCI文件链接oracle12

    Navicat for Oracle是Navicat系列中专门针对Oracle数据库设计的一款产品。它提供了图形化的用户界面,使得数据库管理和开发工作更为便捷。通过Navicat,你可以执行SQL查询,管理数据,创建和编辑数据库对象,甚至...

    oracle入门系列.docx

    理解Oracle的系统概念,即一系列相互关联的组件协同工作的整体,对于全面掌握Oracle数据库的运作至关重要。 总之,"Oracle入门"课程旨在为学生构建坚实的Oracle数据库理论基础,并通过实践操作增强其应用能力,为...

    一本经典的Oracle教程

    本经典Oracle教程向读者介绍了一系列Oracle数据库的关键知识点和操作技能,包括但不限于以下几个方面: 1. Oracle安装:这部分内容详细讲述了如何安装Oracle数据库。安装过程包括下载安装包、解压文件、运行安装...

    不用装Oracle客户端实现C#.NET连接远程Oracle数据库的一种方法

    本文将详细介绍一种无需安装Oracle客户端,仅使用C#.NET就能连接远程Oracle数据库的方法,这对于轻量级的开发环境或者不希望安装大型客户端的场景尤其适用。 首先,你需要下载Oracle的数据提供程序,即Oracle Data ...

    本oracle菜鸟的一次oracle恢复笔记

    本oracle菜鸟的一次oracle恢复笔记

    基于C#连接Oracle数据库Oracle.ManagedDataAccess

    首先,Oracle.ManagedDataAccess是Oracle公司提供的一个纯.NET框架的客户端驱动,它允许开发者在不安装Oracle客户端的情况下,直接与Oracle数据库进行交互。这个库包含了所有必要的组件,使得C#程序可以方便地执行...

    BLOG_Oracle_lhr_Oracle锁系列.pdf

    BLOG_Oracle_lhr_Oracle锁系列.pdfBLOG_Oracle_lhr_Oracle锁系列.pdf

    Oracle系列培训教程之一: oracle简介.doc

    ### Oracle系列培训教程知识点概览 #### 一、Oracle公司及产品概述 Oracle,寓意“甲骨文”,作为全球第二大软件公司,自1979年起便深耕于数据库技术领域,率先推出了基于SQL标准的关系数据库产品。Oracle不仅以其...

    Oracle 11 Dg 一主两备的搭建步骤.docx

    redhat 7.6 oracle 11.0.2.4 DataGuard 搭建详细步骤

    cx_Oracle使用手册

    cx_Oracle模块提供了一系列数据库操作功能,例如执行SQL查询、存储过程调用以及处理大型二进制对象(LOB)等。使用cx_Oracle,Python程序员能够开发出与Oracle数据库交互的应用程序。 根据手册内容,cx_Oracle模块...

Global site tag (gtag.js) - Google Analytics