【Oracle】创建表

news2024/11/19 2:19:20

目录

方法一:CREATE TABLE 语法

创建表示例1:创建stuinfo(学生信息表)

创建表示例2:添加stuinfo(学生信息表)约束

方法二:CREATE TABLE AS 语法

创建表示例3:

创建表示例4:实现对select查询的结果进行快速备份

创建表示例5:复制另一个表的选定列

创建表示例6:从多个表复制选定的列

方法一:CREATE TABLE 语法

CREATE TABLE schema_name.table_name (

    column_1 data_type column_constraint,

    column_2 data_type column_constraint,

    ...

    table_constraint

);

首先,在CREATE TABLE子句中,指定新表所属的表名和模式名称。

其次,在圆括号内列出所有列。如果一个表有多个列,则需要用逗号分隔每个列的定义。列定义包括列名,后跟它的数据类型,例如NUMBER,VARCHAR2和列约束,如NOT NULL,主键,约束检查等。

注意:请注意用户权限问题,必须具有CREATE TABLE系统特权才能在模式中创建新表,并使用CREATE ANY TABLE系统特权在其他用户的模式中创建新表。除此之外,新表的所有者必须具有包含新表或UNLIMITED TABLESPACE系统特权的表空间的配额。

在我们之前创建的JT_CS用户下创建表,一定要有CREATE TABLE权限,不然无法创建数据表。

创建表示例1:创建stuinfo(学生信息表)

 --实例建表stuinfo

 create table JT_CS.stuinfo

 (

   stuid      varchar2(11) not null,--学号:'S'+班号(7位数)+学生序号(3位数)(不能为空)SC200101001

   stuname    varchar2(50) not null,--学生姓名(不能为空)

   sex        char(1) not null,--性别(不能为空)1(男)、2(女)

   age        number(2) not null,--年龄(不能为空)

   classno    varchar2(7) not null,--班号:'C'+年级(4位数)+班级序号(2位数)(不能为空)C200101

   stuaddress varchar2(100) default '地址未录入',--地址 (不填或为空时默认填入‘地址未录入‘)

   grade      char(4) not null,--年级(不能为空)

   enroldate  date,--入学时间

   idnumber   varchar2(18) default '身份证未采集' not null--身份证(不能为空)

 )



 -- Add comments to the table

 --comment on table 是给表名进行注释

 comment on table JT_CS.stuinfo

   is '学生信息表';

 -- Add comments to the columns

 --comment on column 是给表字段进行注释。

 comment on column JT_CS.stuinfo.stuid

   is '学号';

 comment on column JT_CS.stuinfo.stuname

   is '学生姓名';

 comment on column JT_CS.stuinfo.sex

   is '学生性别';

 comment on column JT_CS.stuinfo.age

   is '学生年龄';

 comment on column JT_CS.stuinfo.classno

   is '学生班级号';

 comment on column JT_CS.stuinfo.stuaddress

   is '学生住址';

 comment on column JT_CS.stuinfo.grade

   is '年级';

 comment on column JT_CS.stuinfo.enroldate

   is '入学时间';

 comment on column JT_CS.stuinfo.idnumber

   is '身份证号';

通过上面Crate Table命令创建了stuinfo学生信息表后,还可以继续给表添加相应的约束来保证表数据的准确性。比如:学生的年龄不能存在大龄的岁数,可能是错误数据、性别不能填入不是1(男)、2(女)之外的数据等。

创建表示例2:添加stuinfo(学生信息表)约束

--添加约束

--把stuid当做主键,主键字段的数据必须是唯一性的(学号是唯一的)

alter table JT_CS.STUINFO

  add constraint pk_stuinfo_stuid primary key (STUID);

-- --给字段年龄age添加约束,学生的年龄只能0-60岁之内的

alter table JT_CS.STUINFO

  add constraint ch_stuinfo_age

  check (age>0 and age<=60);

  

--性别不能填入不是1(男)、2(女)之外的数据

alter table JT_CS.STUINFO

  add constraint ch_stuinfo_sex

  check (sex='1' or sex='2');

--年级

alter table JT_CS.STUINFO

  add constraint ch_stuinfo_GRADE

  check (grade>='2000' and grade<='9999');

方法二:CREATE TABLE AS 语法

除了上边Create Table 语句可以创建数据表以外,使用Create Table AS语句一样可以通过复制现有表的列从现有表来创建新表。同时,Create Table 表名 as select 语句也可以实现对select查询的结果进行快速备份。

--语法:SELECT语句可指定列或添加where条件

CREATE TABLE new_table  

AS (SELECT * FROM old_table);

创建表示例3:

CREATE TABLE JT_CS.STUINFO_01 AS (SELECT * FROM JT_CS.STUINFO);

创建表示例4:实现对select查询的结果进行快速备份

新创建的表命名为STUINFO_02,并具有与STUINFO相同的表字段和记录(性别参数小于2的所有记录);

CREATE TABLE JT_CS.STUINFO_02 AS (SELECT * FROM JT_CS.STUINFO WHERE sex<2);

创建表示例5:复制另一个表的选定列

-----语法:

CREATE TABLE new_table AS (SELECT column_1, column2, ... column_n FROM old_table); 



-----示例:创建新表,指定STUNAME, SEX,AGE,CLASSNO四列,并选择SEX小于2的记录。

CREATE TABLE scott.STUINFO_03 AS (SELECT stuname, sex,age,classno FROM  scott.STUINFO WHERE sex<2);

创建表示例6:从多个表复制选定的列

-----语法:

CREATE TABLE new_table AS (SELECT column_1, column2, ... column_n FROM old_table_1, old_table_2, ... old_table_n); 


-----示例:

CREATE TABLE scott.STUINFO_04 AS (SELECT scott.STUINFO.stuname, scott.STUINFO.sex,  scott.STUINFO_01.age,scott.STUINFO_01.classno FROM scott.STUINFO,

scott.STUINFO_01 WHERE scott.STUINFO.stuname = scott.STUINFO_01.stuname AND  scott.STUINFO.sex < 2);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1313697.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用有限制通配符来提升API的灵活性

在Java中&#xff0c;有限制通配符&#xff08;bounded wildcard&#xff09;允许你在泛型中指定一个范围&#xff0c;从而提升API的灵活性。通配符使得你能够编写更通用、适用于多种类型的代码。以下是一个利用有限制通配符提升API灵活性的例子&#xff1a; 假设有一个简单的…

PR模板,复古怀旧电影效果视频制作PR项目工程文件

Premiere复古怀旧电影效果视频制作pr模板项目工程文件下载 这个PR模板以复古城市印象电影质感为特色&#xff0c;结合了电影和数字故障效果。包含6个场景。可以编辑文本、添加媒体和自定义颜色。包含视频教程。4K版本。不需要任何插件。 软件支持&#xff1a;PR2022 | 分辨率&a…

大数据Doris(三十六):Duplicate 模型(冗余模型)介绍

文章目录 Duplicate 模型(冗余模型)介绍 一、创建doris表 二、插入数据

RocketMQ Streams详解

一、RocketMQ Streams 概览 RocketMQ Streams是基于RocketMQ的轻量级流计算引擎。能以SDK方式被应用依赖&#xff0c;无须部署复杂的流计算服务端即可获得流计算能力。 因此具有资源消耗少、扩展性好、支持流计算算子丰富的特点。 1、整体架构​ 数据从RocketMQ中被RocketMQ-…

「X」Embedding in NLP|神经网络和语言模型 Embedding 向量入门

在「X」Embedding in NLP 进阶系列中&#xff0c;我们介绍了自然语言处理的基础知识——自然语言中的 Token、N-gram 和词袋语言模型。今天&#xff0c;我们将继续和大家一起“修炼”&#xff0c;深入探讨神经网络语言模型&#xff0c;特别是循环神经网络&#xff0c;并简要了解…

【postgresql】ERROR: INSERT has more expressions than target columns

执行下面sql insert into apply_account_cancellation3 select * from pply_account_cancellation; 返回下面错误信息 insert into apply_account_cancellation3 select * from apply_account_cancellation > ERROR: INSERT has more expressions than target colu…

ShardingSphereJDBC简单入门

ShardingSphere 介绍ShardingSphere-JDBCSharding-Sphere-ProxyShardingSphere-Sidecar混合架构运行模式DistSQL可拔插架构ShardingSphere的发展路线 主从复制ShardingSphere-JDBC功能SQL解析SQL支持程度SQL稳定支持SQL实验性支持 MySQL不支持SQL清单分页 数据分片垂直分片水平…

世界5G大会

会议名称:世界 5G 大会 时间:2023 年 12 月 5 日-12 月 8 日 地点:河南郑州 一、会议简介 世界 5G 大会,是由国务院批准,国家发展改革委、科技部、工 信部与地方政府共同主办,未来移动通信论坛联合属地主管厅局联合 承办,邀请全球友好伙伴共同打造的全球首个 5G 领域…

KITTI数据集处理为COCO数据集格式

KITTI作为自动驾驶常用数据集&#xff0c;被广泛的应用于自动驾驶目标检测等过程中。 首先是数据集类别合并&#xff0c;原始的KITTI数据集有九个类别&#xff0c;分别是&#xff1a; Car Van Truck Pedestrian Person_sitting Cyclist Tram Misc而我们在使用过程中&#xff0…

使用@ApiModel和@ApiModelProperty的技巧

在现代软件开发中&#xff0c;提供清晰全面的 API 文档 至关重要。ApiModel 和 ApiModelProperty 这样的代码注解在此方面表现出色&#xff0c;通过增强模型及其属性的元数据来丰富文档内容。它们的主要功能是为这些元素命名和描述&#xff0c;使生成的 API 文档更加明确。 Api…

Python Flask-Admin: 构建强大的 Flask 后台管理

概要 Flask-Admin 是一个基于 Flask 的后台管理框架&#xff0c;它提供了丰富的功能和灵活性&#xff0c;使得开发者能够轻松构建功能强大的后台管理系统。在本文中&#xff0c;我们将详细介绍 Flask-Admin 的安装、配置和使用&#xff0c;通过深入的示例代码演示其主要特性。…

【改进YOLOv8】生猪胖瘦评价分级系统:可重参化EfficientRepBiPAN优化Neck

1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 研究背景与意义&#xff1a; 随着计算机视觉和深度学习的快速发展&#xff0c;目标检测成为了计算机视觉领域的一个重要研究方向。目标检测的目标是在图像或视频中准确地识别和定…

LiteClient工具箱:降低成本,减少监管风险

​​发表时间&#xff1a;2023年9月14日 BSV区块链协会的工程团队一直在为即将推出的LiteClient而努力工作&#xff0c;这是一套模块化的组件&#xff0c;可使简易支付验证&#xff08;SPV&#xff09;变得更加便利。 借助LiteClient工具箱&#xff0c;交易所可以通过区块头中…

【学习笔记】JavaScript中的GC算法

1、内存管理 内存&#xff1a;由可读写单元组成&#xff0c;标识一片可操作的空间 管理&#xff1a; 认为的去操作一篇空间的申请、使用和释放 内存管理&#xff1a;开发者主动申请空间、使用空间、释放空间 管理流程&#xff1a; 申请-使用-释放 // 申请 let obj {} //使…

【电路笔记】-电容器

电容器 文章目录 电容器1、概述2、电容器的电容单位3、电容4、电容器示例15、电介质6、额定电压7、总结 电容器是简单的无源器件&#xff0c;当连接到电压源时&#xff0c;可以在极板上存储电荷。 1、概述 在本电容器简介文章中&#xff0c;我们将看到电容器是无源电子元件&am…

采埃孚4D成像雷达拆解

1 基本信息 品牌&#xff1a;海外Tier1采埃孚 • 应用&#xff1a;上汽飞凡中高端纯电平台 • 数量&#xff1a;单车2个&#xff0c;安装在前后保内部 • 最远探测距离&#xff1a;350米 拆解来看&#xff0c;4D雷达主要可以分为4个部分&#xff0c;分别为数字接口板及结构件…

从Aspera到这些替代方案,下载大文件再也不用等待了

在过去&#xff0c;下载大文件往往需要漫长的等待时间&#xff0c;甚至可能会超过数小时或数天。为了解决这个问题&#xff0c;IT行业一直在努力研发新的下载技术和工具&#xff0c;以提高下载速度和效率。本文将深入探讨Aspera替代方案&#xff0c;如何让用户在下载大文件时不…

C# WPF上位机开发(网络程序界面开发)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 之前我们讨论过&#xff0c;设备之间通讯的方式很多。但是&#xff0c;不知道大家有没有注意&#xff0c;前面谈到的这些通讯方式都需要上位机电脑…

4.electron之create-react-app的桌面应用程序

如果可以实现记得点赞分享&#xff0c;谢谢老铁&#xff5e; Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 Electron 将 Chromium 和 Node.js 嵌入到了一个二进制文件中&#xff0c;因此它允许你仅需一个代码仓库&#xff0c;就可以撰写支持 Windows、…

typescript个人学习笔记

https://ts.xcatliu.com/basics/primitive-data-types.html 深受启发 1.剑谱第一页&#xff0c;初始化ts outDir表示把ts编译成js文件&#xff0c;文件编译后存放的位置 2.类型声明 基础数据五种 undefined可以赋值给其他类型引用类型数组对象 //定义数组一 let arr:[][]…