在 Oracle 数据库中,表空间的大小分配如下
段 — 区 — 块
表空间为逻辑结构,数据文件为物理结构
基本语法:
创建临时表空间 或者 永久表空间
CREATE [TEMPORARY] TABLESPACE
tablespace_ name
TEMPFILE |DATAFILE 'xx.dbf' SIZE xX
示例:
下面段代码的意思是:创建一个表空间,并命名为 my_mobile,表存储的位置为 d盘下的 tableSpace 文件,并命名为 my_module.dbf 文件,大小为 100M,空间满后会自己增加,每次增加 32M,大小没有限制
create tablespace my_mobile
datafile 'd:/tableSpace/my_mobile.dbf'
size 100m autoextend on next 32m maxsize unlimited;
设置联机或脱机状态
ALTER TABLESPACE tablespace_ name
ONLINE | OFFLINE;
设置只读或可读写状态
ALTER TABLESPACE tablespace_ name
READ ONLY | READ WRITE
增加数据文件
ALTER TABLESPACE tablespace_ name
ADD DATAFILE 'xx.dbf' SIZE xx;
表空间是一个文件,真真实实存存放在物理硬盘中,如果我们不需要该表空间的时候,就可以对其进行删除处理。但是我们不能直接删除表空间(.dbf)文件,这样会报错。因此我们需要先使用命令行删除在 数据库中的表空间,然后才可以在物理磁盘中删除表空间文件
因此正确的删除表空间的步骤如下:
drop tablespace my_mobile
drop 是个很万能的语句,它还能够直接清空表字段中的数据
语法
create table .表名称(
字段名称1 字段类型 [default 默认值],
字段名称2 字段类型 [default 默认值],
.....
字段名称n 字段类型 [default 默认值]
)
eg:创建一个学生类型的信息表
create table tb_student(
stuId number, -- 学生的ID
stuName nvarchar(8), -- 学生的姓名
stuIdCard number(18,0), -- 学生身份证
stuGender nvarchar2(2) default '男', -- 学生性别,默认为 0
stuAge number(3), -- 学生的年龄
)
语法:
insert into 表名(参数1,参数2,参数3...参数n) values (参数1对应的值,参数2对应的值,....,参数n对应的值);
insert into 表名 values(参数1对应的值,参数2对应的值....,参数n对应的值)
两者的区别如下:
eg:以上面的学生表为例
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111034,320101197905156354,'男',19,2)
在数据库的设计中,约束是必不可少的支持,使用约束可以更好的保证数据库中数据的完整性,约束的作用是定义规则
举几个例子:
约束的分类:
约束分类 | 约束功能 |
---|---|
主键约束 | 主键是唯一的表示,本身不能为空(比如在学校你想确认一个同学,可以通过他的学号定位到他) |
唯一约束 | 在一个表中一次只允许建立一个主键约束,而其他列不希望出现重复值的情况下,可以使用唯一约束。一张表中的唯一约束可以有多个,并且允许有空值 ,空值只能有一个 |
检查约束 | 检查一列的内容是否合格 ,例如:年龄输入加一个限制,在0 ~ 150之间 ,性别,只能是男或者女 |
非空约束 | 字段里面的内容不能为空 |
外键约束 | 在两张表中进行约束操作,这就要区别一下父表和子表的区别啦,父表的 ID 可以对 子表的 ID 具有约束租用 |
关键字:primary key
主键约束可以确认每一行数据的唯一性
eg:还是以上面创建学生表为例
create table tb_student(
stuId number primary key, -- 学生的ID,学生的 ID 作为主键,而且不为空
stuName nvarchar(8), -- 学生的姓名
stuIdCard number(18,0), -- 学生身份证
stuGender nvarchar2(2) default '男', -- 学生性别,默认为 0
stuAge number(3), -- 学生的年龄
-- 另一种创建 主键的方式
-- constraint tb_student_stuId_pk primary key(stuId) pk 是我另外给主键创建的一个名称
)
这个在插入数据的时候,才会出来问题,如果插入两个数据的 ID 相同就会报错
使用了主键约束,就相当于使用了非空约束
在修改表的时候增加主键约束
语法:add coinstraint constraint_name primary key(column_name1 .....);
-- 给学生 id 加上主键
alter table tb_student add contraint pk_id primary key(stuId);
更改约束名称
语法:rename constraint old_name to new_name
alter table tb_student rename pk_id to new_pk_id;
删除主键约束
约束的禁用
语法:disable | enable constraint constraint_name
alter table tb_student disable constraint new_pk_id; -- 约束禁用
alter table drop constraint new_pk_id; -- 删除主键
alter table drop primary key; -- 删除主键约束
关键字:not null
使用非空约束,表示一个字段的内容不允许为空,即:插入数据的时候必须插入内容
创建表的时候增加约束
eg:只用在每个列属性后面加上 not null 就可以啦
create table tb_student(
stuId number primary key, -- 学生的ID,学生的 ID 作为主键,而且不为空
stuName nvarchar(8) not null, -- 学生的姓名
stuIdCard number(18,0) not null, -- 学生身份证
stuGender nvarchar2(2) default '男', -- 学生性别,默认为 0
stuAge number(3) not null -- 学生的年龄
)
修改表时增加约束
语法:alter table table_name modify column_name dataType NOT null;
alter table tb_student modify stuName nvarchar(8) not null;
修改表时去掉非空约束
语法:alter table table_name modify column_name dataType null;
关键字:unique
表示一个字段中的内容是唯一的,其他列不允许重复
eg:使用了这个关键字就要好好注意一下
create table tb_student(
stuId number primary key, -- 学生的ID,学生的 ID 作为主键,而且不为空
stuName nvarchar(8) not null, -- 学生的姓名
stuIdCard number(18,0) unique not null, -- 学生身份证
stuGender nvarchar2(2) default '男', -- 学生性别,默认为 0
stuAge number(3) not null -- 学生的年龄
)
另一种方式设置 唯一约束
create table tb_student(
stuId number primary key, -- 学生的ID,学生的 ID 作为主键,而且不为空
stuName nvarchar(8) not null, -- 学生的姓名
stuIdCard number(18,0) not null, -- 学生身份证
stuGender nvarchar2(2) default '男', -- 学生性别,默认为 0
stuAge number(3) not null -- 学生的年龄
-- 给唯一约束 创建别名
-- 格式 constraint 表名_列名_uk unique (列1,列2),
-- constaint tb_student_stuName_uk unique(stuName)
CONSTRAINT stu_Id_uk UNIQUE(stuIdCard ) -- 唯一约束的另一种方式
)
修改表的时候添加唯一约束
alter table tb_student add constraint stu_Id_uq unique(stuIdCard);
删除唯一约束
alter table xxx disable | enable constraint xxx; -- 暂时禁用
alter table xxx drop constraint xxx; -- 永久删除
关键字:check
使用检查约束来判断一个列中插入的内容是否合法,例如:年龄的取值范围,性别的取值范围
注意:
eg:性别 和 年龄的检查约束
create table tb_student(
stuId number primary key, -- 学生的ID,学生的 ID 作为主键,而且不为空
stuName nvarchar(8) not null, -- 学生的姓名
stuIdCard number(18,0) unique not null, -- 学生身份证
--- test
stuGender nvarchar2(2) default '男' check(stuGender in ('男','女','不详')), -- 学生性别,默认为 0
stuAge number(3) not null check (stuAge between 0 and 150)-- 学生的年龄
-- 检查约束另外起名
-- constraint tb_student_stuAge_ck check (stuAge between 0 and 150)
-- constraint tb_student_stuGender_ck check (stuGender in ('男','女','不详'))
)
删除检查约束
alter table xxx disable | enable constraint xxx; -- 暂时禁用
alter table xxx drop constraint xxx; -- 永久删除
关键字:
主-外键约束是针对两张表的约束
有一张表 TA ,且表有主键,另外一张表中的某一列的数据完全取自于 TA,此时就 TB 表中该列为外键列,添加主外约束来限制它 (TB 外键列上添加)
是不是有点绕口,我换个说法给大家
有两张表 A和B,A 表中的主键记为 AId,表B 的主键记为 BID,表 B 的 BID 加一个 外键,引入 AId,也就是说,以后 Aid 中的所有值,BID 才可以使用
eg:
CREATE TABLE person (
pid VARCHAR2(18),
name VARCHAR2(200)NOT NULL,
age NUMBER(3)NOT NULL,
birthday DATE,
sex VARCHAR2(2)DEFAULT'男”,
CONSTRAINT person_pid_pk PRIMARY KEY(pid),
CONSTRAINT person_name_uk UNIQUE(name),
CONSTRAINT person_age_ck CHECK(age BETWEEN O AND 150),
CONSTRAINT person_sex_ck CHECK(sex IN("男,’女,“中))
);
CREATE TABLE book (
bid NUMBER PRIMARY KEY NOT NULL,
bname VARCHAR(30),
bprice NUMBER(5,2),
pid VARCHAR2(18) REFERENCES person(pid) -- 通过 references 引入外键,这里的外键是主表
-- constraint person_book_pid_fk foreign key(pid) references person(pid)
);
这样就完成了主外键的操作,但是有几点需要注意
总结:
CREATE TABLE person(
pid VARCHAR2(18),
name VARCHAR2(200)NOT NULL,
age NUMBER(3)NOT NULL,
birthday DATE,
sex VARCHAR2(2)DEFAULT'男,
classid CONSTRAINT person_pid_pk PRIMARY KEY(pid),
CONSTRAINT person_name_uk UNIQUE(name),
CONSTRAINT person_age_Ck CHECK(age BETWEEN O AND 150),
CONSTRAINT person_sex_ck CHECK(sex IN‘男’,女,”中”))
);
CREATE TABLE book
(
bid NUMBER PRIMARY KEY NOT NULL,
bname VARCHAR(30),bprice NUMBER(5,2),
pid VARCHAR2(18)CONSTRAINT person_book_pid_fk FOREIGN KE(pid)REFERENCES person(pid)
删除外键约束
alter table xxx disable | enable constraint xxx; -- 暂时禁用
alter table xxx drop constraint xxx; -- 永久删除
约束总共分为五类,分别是:
在使用的时候,如果表已经创建好,我们需要额外添加约束关系的话,可以使用如下方法
增加约束
alter table 表格名称 add constraint 约束名称 增加的约束类型 (列名)
删除约束
alter table 表名 disable | enable constraint 约束类型;
alter table 表名 drop constraint 约束类型; -- 永久删除
序列是一个计数器,它并不会与特定的表相关联。通过创建 Oracle 序列可以实现表的主键自增。序列的用途一般用来填充主键和计数
特性
语法:
create sequence 序列名
increment by n, -- 步长,每次增加的数据
start with n, -- 从 n 开始计数
maxvalue n| nomaxvalue, -- 最大值、无最大值
minvalue n| nominvalue, -- 最小值、无最小值
cycle | nocycle -- 循环序列,不循环
cache n | nocache; -- 缓冲池,将数据加载到内存,提高性能,但是容易损失数据
创建序列:
从 100 开始,每次增加10个步长,最大值 1w,不循环,不进入缓冲池
create sequence dept_deptid_seq
increment by 10
start width 100
maxvalue 10000
nocache
nocycle
nextval 和 currval 伪例
select 序列名.currval from dual --dual 是虚拟表,不存在的表
使用 alert 关键字进行修改
修改序列的增量,最大值,最小值,循环选项,或是否装入内存(不能修改序列的初始值)
alert sequence 表名
increment by 20
maxvalue 99999
nocache
nocycle
修改限制:
drop sequence 表名;
- sequence dropped
赋值结构不复制数据
select * from emp1 as select * from emp where 1 == 2
create table tb_student(
stuId number primary key, -- 主键,内容默认,且不为空
stuIdCard number(18,0) unique not null, -- 唯一 不为空
stuGender nvarchar2(2) default '男',
stuAge number(3) not null check(stuAge between 10 and 30),
pid number(10) REFERENCES tb_teacher(tid), -- 主外键
constraint tb_student_stuGender_ck check(stuGender in('男','女'))
)
create table tb_teacher(
tid number(10) primary key, -- 主键
tIdCard number(18,0) unique not null, -- 身份唯一不为空
tSex nvarchar2(2) default '女',
tage number(3) check(tage between 20 and 70),
constraint tb_teacher_tSex_ck check(tSex in('男','女'))
)
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111034,320101197905156354,'男',19,2)
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111024,120101197905156334,'女',19,3)
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111014,420201198905156354,'男',20,4)
-- 教师数据中没有对应的 tid 值,所以这里是无法插入进去的
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111004,510101197905157354,'女',21,8)
insert into tb_student (stuId,stuIdCard,stuGender,stuAge,tid) values(20171111044,320101192605156354,'男',19,9)
insert into tb_teacher (tid,tIdCard,tSex,tage) values(2,420201198905156354,'女',27)
insert into tb_teacher (tid,tIdCard,tSex,tage) values(3,420201198905156355,'女',37)
insert into tb_teacher (tid,tIdCard,tSex,tage) values(4,420201198905156356,'男',26)
-- 检验
select * from tb_student
select * from tb_teacher
drop table tb_student
drop table tb_teacher
-- 学生 id 的约束
-- primary 约束
CONSTRAINT tb_student_stuId_pk1 PRIMARY KEY(stuId)
-- unique 约束
CONSTRAINT tb_student_stuIdCard_uk UNIQUE(stuIdCard) ,
-- check
CONSTRAINT tb_student_stuAge_ag CHECK(stuAge BETWEEN 10 AND 30)
constraint tb_student_stuGender_ck check(stuGender in('男','女'))
-- 老师 id 的约束
-- primary
CONSTRAINT tb_teacher_tid_pk2 PRIMARY KEY(tid)
-- unique
CONSTRAINT tb_teacher_tIdCard_tk UNIQUE(tIdCard)
-- check
CONSTRAINT tb_teacher_tage_ag1 CHECK(tage BETWEEN 20 AND 70)
constraint tb_teacher_tSex_ck check(tSex in('男','女'))
create table tb_student(
stuId number primary key, -- 主键,内容默认,且不为空
stuIdCard number(18,0) unique not null, -- 唯一 不为空
stuGender nvarchar2(2) default '男',
stuAge number(3) not null check(stuAge between 10 and 30),
pid number(10) REFERENCES tb_teacher(tid), -- 主外键
constraint tb_student_stuGender_ck check(stuGender in('男','女')),
-- 级联删除操作
constraint tb_teacher_tb_student_pid fk foreign key(pid) references tb_teacher(tid) on delete cascade
-- 设置null 操作
constraint tb_teacher_tb_student_pid fk foreign key(pid) references tb_teacher(tid) on delete set null
)
create SEQUENCE seq_test
INCREMENT BY 2
start width 1
nomaxvalue
cache 30