orcl创建表及管理表
常用的字段数据类型:
.字符串(varchar2(n)) n表示保存最大长度,基本200作用。
.整数(number(n)) n位的整数,也可用int代替
.小数(number(n,m)) m为小数位,n-m为整数位,有时候用float代替
.日期(date) 存放日期
.大文本(clob) 存储海量文字(4G)
.大对象(blob) 存放二进制数据,电影,图片,文字,mp3
---------------------------------------------------------------------------------------------
1、创建表:
create table 表名称 (字段1 数据类型[default 默认值][primary key],...)
create table bqh3 (name varchar2(20) not null, sfz number(18) ,dz varchar2(30),constraint pk_sfz primary key (sfz));
2、表数据及表的复制:
cerate table bqh (select * from 已知表)----从已知表中只复制数据
create table bqh as selec * from 已知表; -----从已知表中复制数据和表结构
create table bqh as select 字段1,字段2 from 已知表 where 1=2;----从已知表复制指定字段包含数据
create table bqh as select * from 已知表 where 1=2; ----从已知表中复制结构但不包含表数据
3、插入数据:
insert into 表名 [(字段1,字段2)] values (值1,值2)----字段与列一一对应
insert into bqh (name,sfz,dz) values ('小白',130684,'XX区1幢');
insert into 表名 values 所有列的值;--------可以省略字段
insert into bqh values ('小白',130684,'XX区1幢');
4、更新数据:
update 表 set 列=新的值 ----更新所有的数据
update bqh set sfz=130636
update 表 set 列=新的值 [where 条件] -----更新满足条件的数据
update bqh set sfz=130636 where name='小白'
--------------------------------------------------------------
select * from 表 for update ----手动更新的数据
select * from bqh for update
select * from 表 for update where 条件
select * from bqh for update where sfz=130636 -----手动更新满足条件的数据
5、删除数据:
delete from 表名称 [where 删除条件...]
delete from 表名 where 条件 -----删除满足条件的数据
delete from bqh where sfz=130636;
delete frombqh ----删除所有数据
commit;
rollback;
查看回收站:show recyclebin
恢复表:flashback table 表名称 to before drop
例如:flashback table bqh to before drop
恢复表数据:rollback
例如:delete from bqh;
rollback;
注意:
①事物的回滚:ROLLBACK 更新操作回到原点。
②事物的提交:COMMIT 真正的更新,一旦提交无法回滚。
6、修改表结构:
alter table 表名称 add (列名称 数据类型 [default 默认值,...]) -----增加表字段
alter table bqh add (jf number(3) default 20)
alter table bqh modify (zf number(2) default 10) ------修改表字段
alter table bqh drop zf --------删除表字段
7、添加约束:
非空约束:not null不希望某字段为空
create table bqh (xh number,xm varcher2(20) not null)
唯一约束:unique 不希望某字段有重复值
create table bqh (xh number,xm varcher2(20) not null,email varchar2(50) unique)
指定唯一约束错误提醒:
create table bqh (xh number,xm varcher2(20) not null,email varchar2(50),constraint uk_email unique(email))
主键约束:primary key 非空约束+唯一约束例,如身份证
create table bqh (xm varcher2(20) not null,sfz number,constraint pk_sfz primary key (sfz))
检查约束:为某数据增加过滤条件,例如:年龄范围,性别等
create table bqh (xm varcher2(20) not null,xb varcher2(10) not null,age number(3),constraint ck_xb check (xb in ('男','女')),constraint ck_age check (age between 0 and 150))
外键约束:约束在两张(父子)表中进行,即字表某个字段的取值由父表决定。
例如:每个人有多本书,父表(人),子表(书)
create table xm (bh number,name varchar2(20) not null,constraint pk_bh primary key (bh))
create table book (bookname varchar2(20) not null,bh number,constraint fk_bh foreign key(bh) references xm(bh))
删除数据时,如果主表中的数据有对应子表数据,应先删除子表记录,再删主表记录。但操作不方便,即可以建立外键约束的时候指定一个级联删除功能,当删除主表数据后,对应的子表中的数据相关联的数据希望将其设置为空。
create table xm (bh number,name varchar2(20) not null,constraint pk_bh primary key (bh))
create table book (bookname varchar2(20) not null,bh number,constraint fk_bh foreign key(bh) references xm(bh)on delete set null)
8、修改约束:
为表增加约束
alter table 表名 add constraint 约束名称 约束类型(字段)
删除表中的约束
alter table 表名 drop constraint 约束名称
9、删除表:
drop table 表
drop table xm cascade constraint purge; --------强制性删除表,不关心约束条件
drop table book cascade constraint purge; --------强制性删除表,不关心约束条件
感谢您的阅读,如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮。本文欢迎各位转载,但是转载文章之后必须在文章页面中给出作者和原文连接。
orcl创建表及管理表的更多相关文章
- Oracle创建表及管理表
转自:https://www.linuxidc.com/Linux/2018-05/152566.htm 1. Oracle表的创建及管理 创建表包括三个要素,表名,列名,数据类型.每个表都有对应 ...
- Oracle入门基础(九)一一创建表和管理表
练习:查询每一年入职人数及总人数 SQL> select count(*) Total, 2 sum(decode(to_char(hiredate,'yyyy'),'1980',1,0)) & ...
- Hive管理表分区的创建,数据导入,分区的删除操作
Hive分区和传统数据库的分区的异同: 分区技术是处理大型数据集经常用到的方法.在Oracle中,分区表中的每个分区是一个独立的segment段对象,有多少个分区,就存在多少个相应的数据库对象.而在P ...
- hive 四种表,分区表,内部,外部表,桶表
Hive四大表类型内部表.外部表.分区表和桶表 一.概述 总体上Hive有四种表:外部表,内部表(管理表),分区表,桶表.分别对应不同的需求.下面主要讲解各种表的适用情形.创建和加载数据方法. 二.具 ...
- hive学习笔记之三:内部表和外部表
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Oracle的表创建和事务管理
Oracle的表创建和事务管理 - CURD,根据查询结果创建新表 - 事务管理 - 什么是事务 ,为什么要用事务 - SQL99事务隔离级别 - Oracle事务隔离级别 - 事务回滚 - 隐式回滚 ...
- Oracle_创建和管理表
创建和管理表 常见的数据库对象 Oracle 数据库中的表 查询数据字典 命名规则 CREATE TABLE 语句 数据类型 使用子查询创建表 ALTER TABLE 语句 删除表 清空表 改变对象的 ...
- 4.windows和Linux下创建oracleusername表空间,表,插入数据,用户管理表等操作
进入超级管理员,运行下面命令 Window下创建数据库.表空间,用户,插入数据等操作 -- 01 创建表空间 -- 注意表空间的路径 依据实际安装环境进行调整 CREATE TABLESPACE ts ...
- Oracle02——oracle分页、子查询、集合运算、处理数据、创建和管理表和其他数据库对象
作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7289451.html --oracle分页(Pageing Query) select ...
随机推荐
- 边界扫描(boundary scan)
边界扫描(Boundary scan )是一项测试技术,是在传统的在线测试不在适应大规模,高集成电路测试的情况下而提出的,就是在IC设计的过程中在IC的内部逻辑和每个器件引脚间放置移位寄存器(shif ...
- [javascript] 看知乎学习js事件触发过程
红色箭头代表捕获阶段 蓝色代表目标阶段 绿色代表冒泡阶段 调用元素对象的addEventListener()方法,参数:事件,回调函数,是否捕获(true代表捕获阶段,false代表冒泡阶段,ie浏览 ...
- 主键(primary key)和唯一索引(unique index)区别
主键一定是唯一性索引,唯一性索引并不一定就是主键. 所谓主键就是能够唯一标识表中某一行的属性或属性组,一个表只能有一个主键,但可以有多个候选索引.因为主键可以唯一标识某一行记录,所以可以确保执行数据 ...
- Zipper(poj2192)dfs+剪枝
Zipper Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 15277 Accepted: 5393 Descripti ...
- Java三大特性:封装,继承,多态
java提高篇(一)-----理解java的三大特性之封装 概念: 封装从字面上来理解就是包装的意思,专业点就是信息隐藏,是指利用抽象数据类型将数据和基于数据的操作封装在一起,使其构成一个不可分割的独 ...
- 1-初识java
目录 java 历史 Java 平台 Java 开发环境 Java 运行原理[简] Java 历史 这里不详细记录java的历史,只是标记出时间点和事件. 时间点 事件 1991 Sun公司成立Gre ...
- JAVA设计模式详解(二)----------观察者模式
有一个模式可以帮助你的对象知悉现况,不会错过该对象感兴趣的事,对象甚至在运行时可以决定是否要继续被通知,如果一个对象状态的改变需要通知很多对这个对象关注的一系列对象,就可以使用观察者模式 .观察者模式 ...
- python基础技巧综合训练题2
1,判断一个字符串中的每一个字母是否都在另一个字符串中,可以利用集合的特性来解,集合的元素如果存在,再次更新(update) 是添加不进集合的,那么集合的长度还是跟原来一样,如果添加进去,集合长度就会 ...
- Codeforces550C(SummerTrainingDay01-H)
C. Divisibility by Eight time limit per test : 2 seconds memory limit per test : 256 megabytes input ...
- RBAC 介绍 (权限)
RBAC是什么? RBAC是基于角色的访问控制(Role-Based Access Control )在RBAC中,权限与角色相关联,用户通过成为适当角色的成员而得到这些角色的权限.这就极大地简化了权 ...