技术标签: sql数据类型转换oracle
对于Oracle中的sql来说,数据类型的支持非常全面,无论是数据计算还是复杂的业务逻辑封装需要,数据类型的支持都是内置和可扩展的
数据类型对于每一种编程语言而言都是数据存储的基础,对于编程语言的实现功能而言也是一个标尺,有些编程语言可能数据类型很丰富,比如java,c,在数据计算方面的支持很全面,有些编程比较精简,更侧重于实现特定的功能,数据类型也就简单得多。比如说shell。
对于Oracle中的sql来说,数据类型的支持非常全面,无论是数据计算还是复杂的业务逻辑封装需要,数据类型的支持都是内置和可扩展的。可以根据需要来选择。
目前Oracle的数据类型分类大体有如下的结构。
用户自定义类型,基本上都是由type来实现,可以根据需要来灵活定制。
内置数据类型是主要的应用方向。大体分为了标量,集合,关系型
关于自定义数据类型有必要多说一些。
Oracle PL/SQL复合数据类型
Oracle数据类型学习笔记
Oracle定义数据类型Type
Oracle DB 隐式和显式数据类型转换
Oracle常用数据类型和完整性约束
Oracle 4个大对象(lobs)数据类型介绍
一个简单的例子如下,我们创建测试表test_datatype来简单的说明。
create table test_datatype(id number,name varchar2(100),memo varchar2(1000));
create or replace type t_test_datatype as
object
(
id number,
name varchar2(100)
)
/
create or replace type tt_test_datatype as table of t_test_datatype
/
create table new_test_datatype
(
object_id number,
other_columns tt_test_datatype
)
nested table other_columns store as other_columns_nt
/
而对于内置数据类型,简单的总结和描述总结成了表格。
数据类型
长度
说明
CHAR(n BYTE/CHAR)
默认1字节,n值最大为2000
末尾填充空格以达到指定长度,超过最大长度报错。默认指定长度为字节数,字符长度可以从1字节到四字节。
NCHAR(n)
默认1字符,最大存储内容2000字节
末尾填充空格以达到指定长度,n为Unicode字符数。默认为1字节。
NVARCHAR2(n)
最大长度必须指定,最大存储内容4000字节
变长类型。n为Unicode字符数
VARCHAR2(n BYTE/CHAR)
最大长度必须指定,至少为1字节或者1字符,n值最大为4000
变长类型。超过最大长度报错。默认存储的是长度为0的字符串。
VARCHAR
同VARCHAR2
不建议使用
NUMBER(p[,s])
1-22字节。
存储定点数,,值的绝对值范围为1.0 x 10 -130至1.0 x 10 126。值大于等于1.0 x 10 126时报错。p为有意义的10进制位数,正值s为小数位数,负值s表示四舍五入到小数点左部多少位。
P取值范围1到38
S取值范围-84到127
BINARY_FLOAT
5字节,其中有一长度字节。
32位单精度浮点数类型。
符号位1位,指数位8位,尾数位23位。
BINARY_DOUBLE
9字节,其中有一长度字节。
64位双精度浮点数类型。
对于一些数据样例,总结如下:
输入数据
数据类型
存储结果
7,456,123.89
NUMBER
7456123.89
7,456,123.89
NUMBER(*,1)
7456123.9
7,456,123.89
NUMBER(9)
7456124
7,456,123.89
NUMBER(9,2)
7456123.89
7,456,123.89
NUMBER(9,1)
7456123.9
7,456,123.89
NUMBER(6)
(not accepted, exceeds precision)
7,456,123.89
NUMBER(7,-2)
7456100
本文永久更新链接地址:
本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网
import openpyxl #导入包openpyxlwb = openpyxl.Workbook() #利用workbook方法新建工作薄sheet = wb.create_sheet(“aaa”) #利用此方法可以一直新建工作表,并插入指定的工作表位置sheet2 = wb.create_sheet(“bbb”,1)sheet3 = wb.create_sheet(“ccc”,1)ws=wb.active
查看github教程https://github.com/alibaba/form-render
TCP/IP参考模型是一个非常基础,而且也非常重要的基础框架,要想入门数通这是个必须掌握的基本概念,本文档通过一个简单的示例,结合参考模型来分析一下数通的基本过程。 网络环境非常简单,如下图所示,我们现在来分析一下PC去访问Webserver的WEB服务,整个数据通信过程是如何发生的,为了简化描述,我们这里暂时忽略DNS、ARP、帧校验等等机制的工作细节,只考虑
转:https://blog.csdn.net/Felix_ar/article/details/102732941
共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式。两个不同进程A、B共享内存的意思是,同一块物理内存被映射到进程A、B各自的进程地址空间。进程A可以即时看到进程B对共享内存中数据的更新,反之亦然。由于多个进程共享同一块内存区域,必然需要某种同步机制,互斥锁和信号量都可以。采用共享内存通信的一个显而易见的好处是效率高,因为进程可以直接读写内存,而不需要任何数据的拷贝。因此,采用共享内存的
E-charts的基本使用以及在react项目中引入echarts,和echarts的全部配置。
前言在学习Java基础的过程中,泛型绝对算得上是一个比较难理解的知识点,尤其对于初学者而言,而且就算是已经有基础的Java程序员,可能对泛型的理解也不是那么透彻,属于那种看了明白,时间长了就忘的那种,究其根本,还是对泛型不够理解。大部分人对泛型的认识:“基础知识,但是比较模糊”第一篇:脑图篇1.1 手绘 Spring 架构脑图1.2 手绘 Spring5 架构脑图1.3 手绘 Spring Security 架构脑图1.4 手绘 Spring Boot 架构脑图1.5 手绘Sprin
JUC class1、Package->atomicclass AtomicBooleanclass AtomicIntegerclass AtomicIntegerArrayabstract class AtomicIntegerFieldUpdaterclass AtomicLongclass AtomicLongArrayabstract class AtomicLongFieldUpda...
什么是AOP? AOP即面向切面编程,能够让我们在不影响原有功能的情况下,对程序进行横向扩展,面向切面?横向扩展?第一次接触这两个词的时候我也是一脸懵逼。 说说我的理解:如果现有某个类的某个方法是已经封装好的,现在我们需要在执行这个方法的时候加点自己的东西,对原方法的执行进行干预。当然要求是不能破坏原类。这时需要AOP思想,把这个方法,即切点扩展成一个面来进行操作...
基于 Alchemy 实现 AS3 与 C++ 交互(1)C++ 回传 Array 给 AS3作者:柳大·Poechant邮箱:[email protected]博客:blog.csnd.net/poechang日期:March 26th, 20120 Alchemy 的使用请参考 Adobe 官网,这里不赘述。1 C++ 代码1.1 接口函数// AS3 Array 以参数形式传入
elasticsearch 集群的搭建 和 概念这里不说可以参考以下地址:https://www.cnblogs.com/chenmc/tag/elasticSearch/,主要记录下,自己工作中要去集成es 时,选用操作es的方式三种方式操作es的主要有三种方式: 第一种 :spring date es ,这种方式简单,多用于一些简单业务,但因为方法都帮你封装好了,灵活度不高!(复杂业...
安装office2010常见的提示错误解决办法2011年08月02日 星期二 下午 10:33安装office2010常见的提示错误解决办法:默认情况下,安装程序创建标准日志文件,并将其作为文本文件保存在用户计算机上的 %Temp% 文件夹中。如果安装失败,安装程序会在同一位置创建详细的日志文件,该文件以导致失败的程序包开头。若要更改日志记录选项,请在记事本中打开 Config.x