附件:Oracle参考文档,本人认为是最好的一个。
一、 约束
1、 分类
a) 主键约束(PRIMARY KEY):表示一个唯一标识,本事不为空
在创建表的时候加入主键又两种方法
(1)在字段后面加上关键字,primary key
如:ID NUMBER(5) PRIMARY KEY
(2)一种是在所有字段后加上语句
constraint person_id_pk primary key(pid);
b) 唯一约束(UNIQUE):不允许有重复值
创建唯一约束的方法同样有两种,同主键约束。
如:NAME VARCHAR2(15) UNIQUE
c) 检查约束(CHECK):检查一个列的内容是否合法
创建检查约束的条件两种:
(1) 在字段后加关键词
sex varchar2(2) check(sex in (‘男’,女’))
(2) 加constraint语句
constraint person_age_ck check(sex in(‘男’, ‘女’))
d) 非空约束(NOT NULL)
如:ENAME VARCHAR2(10) NOT NULL
e) 外键约束(foreign key):在两张表中进行约束
constraint person_book_pid_fk foreign key(pid) references person(pid);
2、 使用外键时应注意
a) 在子表中设置的外键在父表中必须是主键
b) 删除时应先删除子表,再删除父表
也可以使用cascade语句强制删除,如:
drop table book cascade constraint;
c) 使用级联删除
在外键约束中加入语句:on delete cascade
如:constraint person_book_pid_fk foreign key(pid) references person(pid) on delete cascade
3、 修改约束
a) 添加约束
如:alter table person add constraint person_pid_pk primary key(pid)
b) 删除约束
alter person drop constraint person_age_ck;
二、 ROWNUM
如果不用子查询,则只能使用<号进行查询,使用子查询则可以使用各种逻辑符号。
1、 显示前5条记录
select * from emp where rownum<=5;
2、 显示前6-10条数据
select * from
(select rownum rn, empno, ename from emp where rownum<=10) temp
where temp.rn>5;
三、 集合操作
1、 UNION:将多个查询的结果组合到一个查询结果中,没有重复内容
UNION ALL:将多个查询的结果组合到一个查询结果中,有重复内容
2、 INTERSECT:返回多个查询结果中相同的部分(交集)
3、 MINUS:返回两个查询结果的差集
用法为 查询结果 关键字 查询结果
四、 序列
1、 创建语法
create sequence seq_name
[increment by n][start with n]
[maxvalue n | nomaxvalue]
[cycle|nocycle]
[cache n| nocache]
2、 创建序列完成之后,所有的自动增长由用户自己处理,在序列中提供了一下两种操作:
a) nextVal:取得学列的写一个内容
b) currVal:取得学列的当前内容
3、
五、 同义词:可以让其他用户通过一个名称方便地访问“用户名.表名称”
1、 创建语法
CREATE SYNONYM 同义词名称 FOR 用户名.表明
如:create synonym emp for scott.emp
2、 删除同义词
drop synonym emp;
3、
六、 用户管理
1、 创建语法
create user 用户名 identified by 密码
2、 只有用管理员权限,才能创建用户
3、 为用户分配权限
a) 语法
grant 权限1, 权限2,….to 用户
如:将创建session的权限给test用户
grant create session to test
b) 如果要把多个权限一次性赋予一个用户,则可以将这些权限定义成一组角色。
Oracle提供了两个主要的角色,分别为CONNECT, RESOURCE。
GRANT CONNECT, RESOURCE TO test
c) 修给密码
ALTER USER 用户名 IDENTIFIED BY 密码
d) 在一般系统中,用户第一次登陆时可以修改密码,要完成此功能,可以手工让一个密码失效,格式如下:
ALTER USER 用户名 PASSWORD EXPIRE
e) 锁住用户
ALTER USER 用户名 ACCOUNT LOCK
解锁用户:ALTER USER 用户名 ACCOUNT UNLOCK
f) 如果新建用户想访问其他用户的表,需要授予此张表的访问权限
GRANT SELECT, DELETE ON scott.emp TO test
回收权限,使用REVOKE关键字
REVOKE SELECT, DELETE ON scott.emp FROM test
4、
七、 数据库备份和恢复
1、 数据库备份使用关键字exp
从cmd下进入到备份文件夹,使用命令exp
输入要备份的用户
2、 数据库恢复使用关键字:imp
进入到备份数据的文件夹,输入命令imp
输入备份的用户
八、 嵌套表:一个表中包含另一个子表
1、 数据库在创建数据表时都要指定字段的类型,所以嵌套表本身也同样需要指定类型,这种类型需要单独定义:
CREATE TYPE project_ty AS OBJECT(
proid NUMBER(4),
proname VARCHAR2(50) ,
prodate DATE
);
/
2、 在定义类型的时候不能加上约束条件
3、 定义类型名称:
CREATE TYPE project_nt AS TABLE OF project_ty;
4、 利用自定义类型创建表
CREATE TABLE department(
deptno NUMBER(2) PRIMARY KEY,
dname VARCHAR2(50) NOT NULL,
projects project_nt
) NESTED TABLE projects STORE AS project_nt_tab_temp;
指定嵌套表存储的位置
5、 插入数据
INSERT INTO department(deptno, dname, projects) VALURS(1, ‘技术部’,
project_nt(
project_ty(1001, ‘ERP’ ,sysdate)
project_ty(1002, ‘AO’ ,sysdate)
));
6、 查询嵌套表信息
SELECT * FROM TABLE (SELECT projects FROM department WHERE deptno=1);
7、 更新嵌套表
UPDATE TABLE (SELECT projects FROM department WHERE deptno=1) pro
set value(pro) = project_ty(‘1001’, ‘嵌套项目’,TO_DATE(‘2010-3-3’, ‘yyyy-mm-dd’));
8、
九、 可变数组(属于嵌套表的升级版本,可变数组中实际上是内部的嵌套表的内容的长度进行了限制)
1、 定义可变数组
定义Object TYPE同嵌套表
CREATE TYPE worker_info_list AS VARRAY(10) OF worker_info
2、 表的查询和更新统嵌套表
十、 数据库设计范式
1、 第一范式(1NF)
每个属性的值域第一范式都是不可分的简单数据项的集合。
2、 第二范式(2NF):如学生和课程,设计成三张表
如果关系R是1NF,而且每一个非主属性都完全依赖于R的键,则R称为第二范式关系模型。
3、 第三范式(3NF):解决多对一问题,如学生和学院,最好设置成两张表
如果R是2NF,而且它的任何一个非键属性都不传递得依赖于任何候选键,则R称为第三范式关系模型。
分享到:
相关推荐
学习概要总结
二、创建表 创建表是数据库设计的第一步,使用CREATE TABLE语句定义表结构,包括字段名、数据类型、约束条件(如NOT NULL、UNIQUE、PRIMARY KEY、FOREIGN KEY等)。理解各种数据类型(如NUMBER、VARCHAR2、DATE等)...
根据给定的Oracle相关命令和描述,我们可以总结出以下关键知识点: ### Oracle系统参数与内存管理 1. **查看系统参数** - `show parameters ga;`:这应该是`show parameters`的一个错误输入,用于显示当前数据库...
二、游标的分类 Oracle 游标可以分为两类:静态游标和动态游标。 1. 静态游标:静态游标是使用 cursor...is 语句定义的游标,它可以对查询语句(select)返回的多条记录进行处理。 2. 动态游标:动态游标是在运行...
这篇笔记总结将深入探讨Oracle的核心概念、关键功能以及常见操作,旨在帮助读者理解和掌握Oracle数据库的关键知识点。 一、Oracle数据库基础 Oracle数据库采用SQL(结构化查询语言)作为其主要的数据交互方式,支持...
#### 二、Oracle 日期处理 1. **EXTRACT 函数** - 用于提取日期或时间戳的特定部分。 - 示例:`SELECT EXTRACT(YEAR FROM create_time) AS 创建日期 FROM orders1;` 2. **TO_CHAR 函数** - 将日期转换为指定...
结合前期报业、运输业、制造业的项目,通过具体的Oracle ERP二次开发项目的实践经验,对Oracle ERP二次开发的方法进行归纳和总结,形成Oracle ERP二次开发的实践流程,规范开发过程,缩短项目时间,减少开发成本。...
Oracle 学习总结 Oracle 是一种关系数据库管理系统,由 Larry Ellison 和 Bob Miner 于 1977 年创立。它是一种对象关系数据库管理系统,支持多种编程语言,包括 Java、Python、C++ 等。 一、创建 Oracle 数据库...
### Oracle性能优化总结 #### 一、选用适合的Oracle优化器 在Oracle数据库中,有三种主要的优化器模式:基于规则(RULE)、基于成本(COST)和选择性(CHOOSE)。每种模式的选择都会直接影响到SQL语句的执行效率。...
#### 二、彻底清除原有Oracle安装记录的方法 - **删除注册表中的Oracle相关项**: - **HKEY_LOCAL_MACHINE / SOFTWARE / Oracle**:该键下保存了大量与Oracle相关的配置信息,包括版本号等。 - **HKEY_LOCAL_...
二、Oracle全套命令 Oracle提供了丰富的命令行工具,如SQL*Plus,用于数据库的管理、查询和维护。其中,SQL*Plus中的SQL命令包括DML(数据操纵语言)如INSERT、UPDATE、DELETE,DDL(数据定义语言)如CREATE、ALTER...
### Oracle数据库总结 #### 一、Oracle数据库安装与卸载详解 ##### 1. Oracle数据库安装注意事项 在安装Oracle数据库之前,确保系统满足最低硬件和软件要求。安装过程中需特别注意的是用户权限设置,尤其是对`...
"Oracle DBA 面试题总结" Oracle DBA 面试题总结是 Oracle 数据库管理员需要掌握的重要知识点的汇总。本文将从 SQL 调优、执行计划、索引、绑定变量、执行计划稳定性、排序相关内存等方面对 Oracle DBA 面试题进行...
- `PATH`:系统路径,包含 Oracle 的二进制执行文件路径和其他常用工具路径。 通过命令 `env | grep -i sid` 可以查看 `ORACLE_SID` 的设置情况;`env | grep ORACLE_BASE`、`env | grep ORACLE_HOME` 和 `env | ...
### Oracle实验二:体系结构、存储结构与各类参数 #### 实验目的 1. **理解Oracle体系结构**:包括逻辑组件如表空间、段、区等;物理组件如数据文件、控制文件、重做日志文件等。 2. **了解初始化参数文件以及初始...
【Oracle DB优化总结】 在数据库管理系统中,Oracle Database(Oracle DB)因其稳定性和高性能而备受赞誉,但随着数据量的增长,优化数据库性能显得至关重要。本文将深入探讨Oracle DB的优化策略,包括优化器的选择...
"Windows Server 2008 安装 Oracle 11g 详细笔记总结" 本文将详细介绍如何在 Windows Server 2008 上安装 Oracle 11g,包括安装前的准备工作、安装过程、安装后的配置和基本操作。 一、安装前的准备工作 在安装 ...