Oracle(11)Managing Tables

news/2024/11/22 18:13:32/

Managing Tables 管理表

目标:

  • 识别存储数据的各种方法
  • 概述甲骨文数据类型
  • 区分扩展ROWID与限制ROWID
  • 勾勒出一行的结构
  • 创建常规表和临时表
  • 管理表中的存储结构
  • 重新组织、截断和删除表
  • 删除表中的列 

一、基础知识

1、Oracle Built-in Data Types Oracle内置数据类型

2、CHAR&VARCHAR2 数据类型对比

CHAR类型未使用的空间也会占据,而VARCHAR2类型的则会释放掉未使用的空间。

所以在实际开发中尽量使用VARCHAR2类型

3、ROWID Format 行id号格式

查询rowid的方法:

Locating a Row Using ROWID 使用ROWID定位行

ROWID是一种数据类型,可以与表中的其他列一起查询。具有以下几个特点:

  • ROWID是数据库中每一行的唯一标识符。
  • ROWID不显式存储为列值。
  • 虽然ROWID不直接给出一行的物理地址,但它可以用来定位该行。
  • ROWID提供访问表中某行的最快方法。
  • ROWID存储在索引中,以指定具有给定一组键值的行。

快速定位原因:

  • 因为一个段只能驻留在一个表空间中,通过使用数据对象号,甲骨文服务器可以确定包含一行的表空间。
  • 表空间中的相对文件号用于定位文件,块号用于定位包含该行的块,行号用于定位该行的行目录项。
  • 行目录项可用于定位行的开头。
  • 因此,ROWID可用于定位数据库中的任何行。

4、Structure of a Row 行的结构

  • 行数据作为可变长度记录存储在数据库块中。行的列通常按照其定义的顺序存储,不存储任何尾随的NULL列。
  • 注意: 对于非尾随NULL列,列长度需要一个字节。表中的每一行都有:
    • 行标头:用于存储行中的列数、链接信息和行锁定状态
    • 行数据:对于每个列,甲骨文服务器存储列长度和值(一个字节是需要存储列长度,如果列将需要超过250个字节的存储,在这种情况下,三个字节将用于列长度) 。列值存储在列长度字节之后。)
  • 相邻行之间不需要任何间距。块中的每一行在行目录中都有一个槽。目录槽指向行的开头。

二、基础操作

1、Creating a Table 创建表

CREATE TABLE hr.employees(
employee_id NUMBER(6),
first_name VARCHAR2(20),
last_name VARCHAR2(25),
email VARCHAR2(25),
phone_number VARCHAR2(20),
hire_date DATE DEFAULT SYSDATE,
job_id VARCHAR2(10),
salary NUMBER(8,2),
commission_pct NUMBER (2,2),
manager_id NUMBER(6),
department_id NUMBER(4))
TABLESPACE USERS;


http://www.ppmy.cn/news/1200878.html

相关文章

Linux Shell和权限

目录 Shell命令及运行原理 权限 1.文件基本属性 2.文件权限值的表示方法 3.文件访问权限的相关设置方法 3.(1)chmod 组名修改 3.(2)chmod 二进制修改 3.(3)chown 3.(4)chgrp 3.(5)umask 4.目录权限 Shell命令及运行原理 Linux的操作系统,狭义上是…

maven 项目添加 git-hook 脚本,约束提交内容格式

git 提交代码&#xff0c;推送代码&#xff0c;可以通过在 .git/hooks 目录中的 bash 脚本来做一定的验证工作。 本例使用插件 maven-antrun-plugin 自动输出脚本至 .git/hooks 目录中&#xff0c;在 pom.xml 中的使用示例如下&#xff1a; <plugin><groupId>org.…

golang实现极简todolist

ToDoList 最近跟着qimi老师做了一个ToDoList&#xff0c;我做的GitHub地址贴在这里&#xff0c;但由于前端出了点问题&#xff0c;所以都是用postman进行测试 原项目地址 部分功能展示 删除代办 查找代办 下面给出思路 思路 其实这是一个很简单的增删改查的实现&#xff…

【学习推荐】极客时间-左耳听风专栏

我从未看到过如此系统全面立体的阐述整个计算机学习脉络的教程。非常建议直接入手一份&#xff0c;首单特价98&#xffe5; 极客时间。推荐码也没几块钱&#xff0c;我就不贴我的返利了&#xff0c;如果囊中带涩也可以几个人拼一份&#xff0c;建议官网而不是拓印版。为什么建议…

一个使用zmq_recv 接收 5555端口的demo

以下是一个使用ZeroMQ库的C语言代码示例&#xff0c;该代码创建一个ZMQ的REP套接字&#xff0c;连接到5555端口&#xff0c;并接收消息&#xff1a; #include <zmq.h> #include <stdio.h> #include <unistd.h> #include <string.h>int main (void) {v…

基于深度学习的菠萝与果叶视觉识别及切断机构设计

收藏和点赞&#xff0c;您的关注是我创作的动力 文章目录 概要 一、课题内容二、总体方案确定2.1 方案选择2.2 菠萝的视觉识别流程2.3 菠萝果叶切断机构设计流程 三 基于深度学习的菠萝检测模型3.1 卷积神经网络简介3.2 YOLO卷积神经网络3.3 图像采集与数据制作3.4 数据训练与…

【NI-DAQmx入门】外部采样时钟相关

1.时钟的作用 时钟在几乎所有测量系统中都起着至关重要的作用。通过硬件定时测量&#xff0c;时钟控制采样或更新的发生时间。与依赖软件计时测量相比&#xff0c;您可以选择硬件定时测量来实现采样或更新之间更一致的时间间隔。以数模转换器特性分析为例。该应用由三个基本部分…

记录:Unity脚本的编写5.0

目录 前言创建动画Unity Animation、Animator常用类关于两者的区别Animator 编写脚本 大型连续剧之在untiy中&#xff08;或者别的什么活动&#xff09; 前言 之前在场景中添加了背景音乐&#xff0c;而在我们的日常的体验中&#xff0c;可以发现游戏或者场景中有很多有趣的动…