1:用户和权限
1.1 用户的创建
a)语法--- create user 用户名 identified by 密码;
b)创建用户abcd,并设定密码为abcd;---注意:操作数据库对象是需要DBA(数据库管理员)权限的;
create user abcd identified by bjsxt;
1.2 给用户授权
Oracle中的权限很多,为了方便用户管理权限,提供了角色这个概念。角色代表一个身份,该身份拥有固定的权限。常见的角色:DBA(数据库管理员),CONNECT(临时用户,拥有少量的权限),RESOURCE(比较靠谱的权限,拥有更多的权限,不能管理数据库);
a)给abcd用户授予普通用户的权限
grant connect,resource to abcd;
b)从abcd用户撤销resource权限
revoke resource from abcd;
1.3 删除用户
drop user abcd;
1.4修改用户
1.4.1修改用户密码
alter user abcd identified by 123;
1.4.2锁定用户和解锁用户
a)锁定用户
alter user abcd account lock;
b)解锁用户
alter user abcd account unlock;
2.数据库表
2.1Oracle中的数据类型
2.1.1字符类型
a)varchar2---可变长度的字符串
b)cahr ---不可变长度的字符串,效率较高;
2.1.2数值类型
number,既可以表示整数,也可以表示浮点数;
2.1.3日期时间类型
a)date,存放日期和时间;
b)timestamp,比date更精确的日期时间类型;
2.1.4 lob类型
a)blob,用于存放二进制数据,可以用于存放文件、图片、音频、视频等二进制数据;
b)clob,用于存放答文本信息;
2.2创建表格
创建学生表,字段包含学号、姓名、性别、年龄、入学日期、班级、email等信息;
create table student(
sno number(4),
sname varchar(12),
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50)
)
2.3修改表格
2.3.1添加字段
alter table student add(score number(3));
2.3.2修改字段的类型
alter table student modify(score number(5,2));
2.3.3重命名字段
alter table student rename column score to fenshu ;
2.3.4删除字段
alter table student drop column fenshu;
2.3.5删除表格
drop table stu;
3.表格的约束
constraints,约束,用于对表格的额数据进行限制,保证表格数据的完整性和一致性。
语法:constraints 约束名+约束类型(约束字段)
3.1主键约束(primary key)
主键约束用于唯一标识一条记录的字段,必须保证即非空有唯一。
一张表中,只能有一个主键;
a)在表级别定义主键约束,对约束统一管理
create table student (
sno number(4),
sname varchar2(12),
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50),
constraints pk_student primary key (sno)
);
b)在列级别添加主键约束
create table student (
sno number(4) constraints pk_student primary key,
sname varchar2(12),
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50)
);
c)在列级别添加简化版约束
create table student (
sno number(4) primary key,
sname varchar2(12),
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50)
);
d)联合主键,只能在表级别定义,因为一个表只能有一个主键
create table student (
sno number(4),
sname varchar2(12),
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50),
constraints pk_student primary key (sno, email)
);
3.2非空约束not null
字段值不允许为空,非空约束只能在列级别定义
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50),
constraints pk_student primary key (sno)
);
3.3唯一约束 (unique)
要求字段值不能重复;
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50), -- unique,
constraints pk_student primary key (sno),
constraints uk_student_email unique (email)
);
3.4 检查约束(check)
用于限定字段值的取值范围;
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3) check (gender in ('男', '女')),
age number(3),
sdate date,
clazz varchar2(20),
email varchar2(50),
constraints pk_student primary key (sno),
constraints uk_student_email unique (email),
constraints ck_student_age check (age between 18 and 30)
);
3.5外键约束(foreign key)
用于约束表和表之间的关系,两张标的依赖关系,以emp表和dept表为例,emp表依赖dept表,因此,dept表可以被称之为主表,emp表被称之为从表。
注意:
》主表中,只有主键或唯一建才可以被从表参考;
》从表中作为外键的列,类型一定要和主表的被参考列相同;
a)建立主表clazz
create table clazz (
cno number(3) primary key,
cname varchar2(20) not null,
croom number(3)
);
b)建立从表,并定义外键Student
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3) default '男' check (gender in ('男', '女')),
age number(3),
sdate date,
email varchar2(50),
cno number(3),
constraints pk_student primary key (sno),
constraints uk_student_email unique (email),
constraints ck_student_age check (age between 18 and 30),
constraints fk_student_cno foreign key (cno) references clazz (cno)
);
c)也可以在列级别定义外键,如下
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3) default '男' check (gender in ('男', '女')),
age number(3),
sdate date,
email varchar2(50),
cno number(3) references clazz(cno),
constraints pk_student primary key (sno),
constraints uk_student_email unique (email),
constraints ck_student_age check (age between 18 and 30)
);
d)外键中的删除问题;
》主表中的数据在被引用时,无法直接删除,默认情况下,需要先删除主表中的数据。
》可以在定义外建时,设置删除策略为cascade(级联),表示当删除主表的信息时,同时删除从表中的所有关联的信息
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3) default '男' check (gender in ('男', '女')),
age number(3),
sdate date,
email varchar2(50),
cno number(3),
constraints pk_student primary key (sno),
constraints uk_student_email unique (email),
constraints ck_student_age check (age between 18 and 30),
constraints fk_student_cno foreign key (cno) references clazz (cno) on delete cascade
);
》可以在定义外建时,设置删除策略为set null(设空),表示当删除主表的信息时,将从表中的相关数据设置为null
create table student (
sno number(4),
sname varchar2(12) not null,
gender char(3) default '男' check (gender in ('男', '女')),
age number(3),
sdate date,
email varchar2(50),
cno number(3),
constraints pk_student primary key (sno),
constraints uk_student_email unique (email),
constraints ck_student_age check (age between 18 and 30),
constraints fk_student_cno foreign key (cno) references clazz (cno) on delete set null
);
3.6在修改表格时添加约束
a)给student表添加约束
-- 主键约束
alter table student add constraints pk_student primary key (sno);
-- 唯一约束
alter table student add constraints uk_student_email unique (email);
-- 检查约束
alter table student add constraints ck_student_age check (age between 18 and 30);
alter table student add constraints ck_student_gender check (gender in ('男','女'));
-- 外键约束
alter table student add constraints fk_student_cno foreign key (cno) references clazz (cno);