从零开始学习Oracle之数据类型和运算符
sinye56 2024-09-19 02:08 4 浏览 0 评论
数据表由多列字段构成,每一个字段指定了不同的数据类型。指定字段的数据类型之后,也就决定了向字段插入的数据内容,例如,当要插入数值的时候,可以将它们存储为整数类型,也可以将它们存储为字符串类型:不同的数据类型也决定了Oracle在存储它们的时候使用的方式,以及在使用它们的时候选择什么运算符号进行运算。
1.Oracle数据类型介绍
Oracle支持多种数据类型,主要有以下三种:
①数值类型:包括整数类型和小数类型。
②日期/时间类型:包括DATE和TIMESTAMP。
③字符串类型:包括CHAR、VARCHAR2、NVARCHAR2、NCHAR和LONG五种。
1.1数值类型
数值型数据类型主要用来存储数字,Oracle提供了多种数值数据类型,不同的数据类型提供不同的取值范围,可以存储的值范围越大,其所需要的存储空间也会越大。Oracle的数值类型主要通过number(m,n)语句来实现。使用的语法格式如下:
number(m,n)
m的取值范围为1~38,n的取值范围为-84~127。
number(m,n)是可变长的数值列,允许0、正值及负值,m是所有有效数字的位数,n是小 数点以后的位数。
例如:number(6,3),这个字段的最大值是999.999,如果数值超出了位数限制就会被截取多余的位数。
number(3,0),输入数字567.123,保存的数据是567,可以省略number(3,0)中的0,直接写成number(3)。
不同的数值类型的长度不同,取值范围不同,并且需要不同的存储空间,因此,应该根据实际需要选择最合适的类型,这样有利于提高查询的效率和节省存储空间。
1.2 日期与时间类型
Oracle中表示日期的数据类型,主要包括DATE和TIMESTAMP。
1.3 字符串类型
字符串类型用来存储字符串数据。Oracle中的字符串类型指CHAR、VARCHAR2、NCHAR、NVARCHAR2和LONG。
VARCHAR2、NVARCHAR2和LONG类型是变长类型,对于其存储需求取决于列值的实际长度,而不是取决于类型的最大可能尺寸。例如,一个VARCHAR2(10)列能保存最大长度为10个字符的一个字符串,实际的存储需要是字符串的长度。
定长字符串在存储时长度是固定的,而变长字符串的存储长度根据实际插入的数据长度而定。
2.如何选择数据类型
Oracle提供了大量的数据类型,为了优化存储,提高数据库性能,在任何情况下均应使用最精确的类型。即在所有可以表示该列值的类型中,该类型使用的存储最少。
2.1整数和小数
数值数据类型只有NUMBER,它可以存储正数、负数、零、定点数和精度为30位的浮点数。格式为number(m,n),其中m为精度,表示数字的总位数,它在1~38;n为范围,表示小数点右边的数字的位数,它在-84~127。如果不需要小数部分,则使用整数来保存数据,可以定义为number(m,0)或者number(m);如果需要表示小数部分,则使用number(m,n)。
2.2日期与时间类型
如果只需要记录日期,则可以使用DATE类型。如果需要记录日期和时间,可以使用TIMESTAMP类型。特别是需要显示上午、下午或者时区时,必须使用TIMESTAMP类型。
2.3 CHAR与VARCHAR2
CHAR和VARCHAR2的区别:
CHAR是固定长度字符,VARCHAR2是可变长度字符;CHAR会自动补齐插入数据的尾部空格,VARCHAR2不会补齐尾部空格。
CHAR是固定长度,所以它的处理速度比 VARCHAR2的速度要快,但是它的缺点就是浪费存储空间。所以对存储不大,但在速度上有要求的可以使用CHAR类型,反之可以使用VARCHAR2类型来实现。
3.常见运算符
运算符连接表达式中各个操作数,其作用是用来指明对操作数所进行的运算。常见的运算有数学计算、比较运算、位运算以及逻辑运算。运用运算符可以更加灵活地使用表中的数据,常见的运算符类型有:算术运算符、比较运算符、逻辑运算符、位运算符。
3.1运算符概述
运算符是告诉Oracle执行特定算术或逻辑操作的符号。Oracle的内部运算符很丰富,主要有四大类,分别是:算术运算符、比较运算符、逻辑运算符、位操作运算符。
1.算数运算符
算术运算符用于各类数值运算,包括加(+)、减(-)、乘(*)、除(/)。
2.比较运算符
比较运算符用于比较运算,包括大于(>)、小于(<)、等于(=)、大于等于(>=)、 小于等于(<=)、不等于(!=),以及IN、BETWEEN AND、IS NULL、LIKE等。
3.逻辑运算符
逻辑运算符的求值所得结果均为1(TRUE)、0(FALSE),这类运算符有逻辑非(NOT 或者!)、逻辑与(AND或者&&)、逻辑或(OR或者||)、逻辑异或(XOR)。
4.位操作运算符
参与运算的操作数,按二进制位进行运算。这类运算符包括位与(&)、位或(|)、位非 (~)、位异或(^)、左移(<<)、右移(>>)6种。
3.2算数运算符
算术运算符是SQL中最基本的运算符
3.3比较运算符
比较运算符经常在SELECT的查询条件子句中使用,用来查询满足指定条件的记录。
3.4逻辑运算符
3.5运算符的优先级
运算符的优先级决定了不同的运算符在表达式中计算的先后顺序,下表出了Oracle中的各类运算符及其优先级。
一般情况下,级别高的运算符先进行计算,如果级别相同,Oracle按表达式的顺序从左到右依次计算。在无法确定优先级的情况下,可以使用圆括号()来改变优先级,并且这样会使计算过程更加清晰。
相关推荐
- RHEL8和CentOS8怎么重启网络
-
本文主要讲解如何重启RHEL8或者CentOS8网络以及如何解决RHEL8和CentOS8系统的网络管理服务报错,当我们安装好RHEL8或者CentOS8,重启启动网络时,会出现以下报错:...
- Linux 内、外网双网卡路由配置
-
1.路由信息的影响Linux系统中如果有多张网卡的情况下,如果路由信息配置不正确,...
- Linux——centos7修改网卡名
-
修改网卡名这个操作可能平时用不太上,可作为了解。修改网卡默认名从ens33改成eth01.首先修改网卡配置文件名(建议将原配置文件进行备份)...
- CentOS7下修改网卡名称为ethX的操作方法
-
?Linux操作系统的网卡设备的传统命名方式是eth0、eth1、eth2等,而CentOS7提供了不同的命名规则,默认是基于固件、拓扑、位置信息来分配。这样做的优点是命名全自动的、可预知的...
- Linux 网卡名称enss33修改为eth0
-
一、CentOS修改/etc/sysconfig/grub文件(修改前先备份)为GRUB_CMDLINE_LINUX变量增加2个参数(net.ifnames=0biosdevname=0),修改完成...
- CentOS下双网卡绑定,实现带宽飞速
-
方式一1.新建/etc/sysconfig/network-scripts/ifcfg-bond0文件DEVICE=bond0IPADDR=191.3.60.1NETMASK=255.255.2...
- linux 双网卡双网段设置路由转发
-
背景网络情况linux双网卡:网卡A(ens3)和网卡B(...
- Linux-VMware设置网卡保持激活
-
Linux系统只有在激活网卡的状态下才能去连接网络,进行网络通讯。修改配置文件(永久激活网卡)...
- VMware虚拟机三种网络模式
-
01.VMware虚拟机三种网络模式由于linux目前很热门,越来越多的人在学习linux,但是买一台服务放家里来学习,实在是很浪费。那么如何解决这个问题?虚拟机软件是很好的选择,常用的虚拟机软件有v...
- 2023年最新版 linux克隆虚拟机 解决网卡uuid重复问题
-
问题描述1、克隆了虚拟机,两台虚拟机里面的ip以及网卡的uuid都是一样的2、ip好改,但是uuid如何改呢?解决问题1、每台主机应该保证网卡的UUID是唯一的,避免后面网络通信有问题...
- Linux网卡的Vlan配置,你可能不了解的玩法
-
如果服务器上连的交换机端口已经预先设置了TRUNK,并允许特定的VLAN可以通过,那么服务器的网卡在配置时就必须指定所属的VLAN,否则就不通了,这种情形在虚拟化部署时较常见。例如在一个办公环境中,办...
- Centos7 网卡绑定
-
1、切换到指定目录#备份网卡数据cd/etc/sysconfig/network-scriptscpifcfg-enp5s0f0ifcfg-enp5s0f0.bak...
- Linux搭建nginx+keepalived 高可用(主备+双主模式)
-
一:keepalived简介反向代理及负载均衡参考:...
- Linux下Route 路由指令使用详解
-
linuxroute命令用于显示和操作IP路由表。要实现两个不同子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现。在Linux系统中,设置路由通常是为了解决以下问题:该...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- oracle忘记用户名密码 (59)
- oracle11gr2安装教程 (55)
- mybatis调用oracle存储过程 (67)
- oracle spool的用法 (57)
- oracle asm 磁盘管理 (67)
- 前端 设计模式 (64)
- 前端面试vue (56)
- linux格式化 (55)
- linux图形界面 (62)
- linux文件压缩 (75)
- Linux设置权限 (53)
- linux服务器配置 (62)
- mysql安装linux (71)
- linux启动命令 (59)
- 查看linux磁盘 (72)
- linux用户组 (74)
- linux多线程 (70)
- linux设备驱动 (53)
- linux自启动 (59)
- linux网络命令 (55)
- linux传文件 (60)
- linux打包文件 (58)
- linux查看数据库 (61)
- linux获取ip (64)
- linux进程通信 (63)