从零开始学习Oracle之数据类型和运算符
wptr33 2024-12-26 17:06 17 浏览
数据表由多列字段构成,每一个字段指定了不同的数据类型。指定字段的数据类型之后,也就决定了向字段插入的数据内容,例如,当要插入数值的时候,可以将它们存储为整数类型,也可以将它们存储为字符串类型:不同的数据类型也决定了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按表达式的顺序从左到右依次计算。在无法确定优先级的情况下,可以使用圆括号()来改变优先级,并且这样会使计算过程更加清晰。
相关推荐
- 【推荐】一款开源免费、美观实用的后台管理系统模版
-
如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍...
- Android架构组件-App架构指南,你还不收藏嘛
-
本指南适用于那些已经拥有开发Android应用基础知识的开发人员,现在想了解能够开发出更加健壮、优质的应用程序架构。首先需要说明的是:AndroidArchitectureComponents翻...
- 高德地图经纬度坐标批量拾取(高德地图批量查询经纬度)
-
使用方法在桌面上新建一个index.txt文件,把下面的代码复制进去保存,再把文件名改成index.html保存,双击运行打开即可...
- flutter系列之:UI layout简介(flutter ui设计)
-
简介对于一个前端框架来说,除了各个组件之外,最重要的就是将这些组件进行连接的布局了。布局的英文名叫做layout,就是用来描述如何将组件进行摆放的一个约束。...
- Android开发基础入门(一):UI与基础控件
-
Android基础入门前言:...
- iOS的布局体系-流式布局MyFlowLayout
-
iOS布局体系的概览在我的CSDN博客中的几篇文章分别介绍MyLayout布局体系中的视图从一个方向依次排列的线性布局(MyLinearLayout)、视图层叠且停靠于父布局视图某个位置的框架布局(M...
- TDesign企业级开源设计系统越发成熟稳定,支持 Vue3 / 小程序
-
TDesing发展越来越好了,出了好几套组件库,很成熟稳定了,新项目完全可以考虑使用。...
- WinForm实现窗体自适应缩放(winform窗口缩放)
-
众所周知,...
- winform项目——仿QQ即时通讯程序03:搭建登录界面
-
上两篇文章已经对CIM仿QQ即时通讯项目进行了需求分析和数据库设计。winform项目——仿QQ即时通讯程序01:原理及项目分析...
- App自动化测试|原生app元素定位方法
-
元素定位方法介绍及应用Appium方法定位原生app元素...
- 61.C# TableLayoutPanel控件(c# tabcontrol)
-
摘要TableLayoutPanel在网格中排列内容,提供类似于HTML元素的功能。TableLayoutPanel控件允许你将控件放在网格布局中,而无需精确指定每个控件的位置。其单元格...
- 12个python数据处理常用内置函数(python 的内置函数)
-
在python数据分析中,经常需要对字符串进行各种处理,例如拼接字符串、检索字符串等。下面我将对python中常用的内置字符串操作函数进行介绍。1.计算字符串的长度-len()函数str1='我爱py...
- 如何用Python程序将几十个PDF文件合并成一个PDF?其实只要这四步
-
假定你有一个很无聊的任务,需要将几十个PDF文件合并成一个PDF文件。每一个文件都有一个封面作为第一页,但你不希望合并后的文件中重复出现这些封面。即使有许多免费的程序可以合并PDF,很多也只是简单的将...
- Python入门知识点总结,Python三大数据类型、数据结构、控制流
-
Python基础的重要性不言而喻,是每一个入门Python学习者所必备的知识点,作为Python入门,这部分知识点显得很庞杂,内容分支很多,大部分同学在刚刚学习时一头雾水。...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
面试官:git pull是哪两个指令的组合?
-
git pull命令使用实例 git pull--rebase
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mysql max (33)
- vba instr (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)