Oracle学习系列7
Oracle学习系列7
************************************************************************************
关联表的约束:
强制删除关联表中的父表:
drop table tab_name cascade constraint ;
约束本身是可以修改的,但是不建议修改约束
知识点:
,掌握视图的作用及定义
,掌握序列的使用:SEQUENCE
,掌握PowerDesigner设计工具的使用
,了解同义词,了解用户管理,了解嵌套表及可变数组
,理解数据库的设计范式
--------------------------------------------------------
,视图:
封装了一条复杂的查询语句
语法:
create view view_name
as 子查询
{with check option | with read only } ; //不能更新视图的创建条件,不能更改视图数据
建立一个视图,此视图包含了全部部门20的信息:
create view view_emp20
as
select empno,ename, job,hiredate
from emp
;
查询视图:
sele * from view_emp20 ;
删除视图:
drop view view_name ;
ex:
drop view view_emp20 ;
完整语法格式:
create or replace view view_name
as 子查询 //系统会为用户自动进行删除及重建的功能
ex:
create or replace view view_emp20
as
) years
from emp e, dept d
where e.deptno=d.deptno
group by d.dname ;
更新视图:
修改视图中7369的部门编号:
update view_emp20
; //提示更新成功,但是视图表中无编号7369的雇员
--------------------------------------------------------
序列(重点)
在oracle完成自动序列增长的功能,则只能依靠序列完成
格式:
create sequence seq_name
[increment by n] [start with n]
[{maxvalue n |nomaxvalue}]
[{minvalue n | nominvalue }]
[{cycle | nocycle}]
[{cache n | nocache }];
删除:
drop sequence seq_name
ex:创建一个myseq的序列,验证自动增长的操作:
create sequence myseq increment by ;
在序列中提供两种操作:
nextVal:取得序列的下一个内容
currVal:取得序列的当前内容
创建表test_seq:
create table test_seq(
curr number,
next number
);
使用序列:
insert into test_seq(curr,next)
values(myseq.currval,myseq.nextVal) ;
--------------------------------------------------------
同义词(了解):
功能:可以让其他用户通过一个名称方便的访问‘user.table_name’.
语法:
create synonym syn_name for user.tab_name ; //建立
drop synonym syn_name ; //删除
ex: create synonym dual for sys.dual ;
------------------------------------------
select sysdate from dual ;//dual是张虚拟表
conn sys/change_on_install as sysdba ;
select * from tab
where TNAME='DUAL';//在sys用户下存在此表
--------------------------------------------------------
用户管理(了解):
语法:
create user user_name identified by passwd //创建用户(sys用户权限)
[default tablespace default_tablespace]
[temporary tablespace temporary_tablespace ]
grant 权限1,权限2,权限3.. to user ;//给用户授权 create session
alter user user_name identified by passwd_new ; //修改用户密码
eg:
create user kevin identified by root ;
grant conncet, resource to kevin ;
角色:connect 、resource //每个角色有好多不同的权限
解/锁住用户:
alter user user_name account lock /unlock;
eg:
alter user kevin account lock /unlock ;
授权emp表:
grant 权限1,权限2 on user_name.tabl_name to user_name ;
将scott用户下的emp表的查询权限及删除权限给kevin:
grant select ,delete on scott.emp to kevin;
回收权限:
revoke 权限1,权限2,.. on user.tab_name from user_name ;
eg:
revoke select ,delete on scott.emp from kevin ;
grant/(revoke) 权限1,权限2,权限3 on user.tab_name to / (from) user_name ;
--------------------------------------------------------
数据库的备份与恢复(了解):
数据库备份: exp
D:\data>exp
数据库恢复: imp
D:\data>impf
查看错误:show error
--------------------------------------------------------
嵌套表(了解):
在一个表中包含另外一个子表
//创建project_ty类型
create type project_ty as object(
proid number(),
proname varchar(),
prodate date
) ;
/ //最后一个‘/' 不可少
//使用porject_nt类型
create type project_nt as table of project_ty;
/ //最后一个‘/' 不可少
create table department(
deptno number() primary key not null,
dname varchar2() not null,
projects project_nt
) nested table projects store as project_nt_tab_temp ;
对于插入数据来讲,需要指定每个project_ty的数据类型
insert into department(deptno,dname,projects)
values(
,'技术部',
project_nt(
project_ty(,'erp',sysdate),
project_ty(,'crm',sysdate),
project_ty(,'oa',sysdate),
)
);
查询:
select * from department ;
若此时需要查看一个部门的全部项目的话,则需要查询嵌套表:
) ;
更新:
update table ( ) pro
','测试项目',to_date('2016-02-12','yyyy-mm-dd'))
;
--------------------------------------------------------
可变数组(了解):
属于嵌套表的升级版,在可变数组中手机上就是将内部的嵌套表的内容的长度进行了限制。
//定义类型
create type worker_info as object(
id number,
name varchar2(),
sex varchar2()
);
/
//定义数组类型
create type worker_info_list ) of worker_info ;
/
//创建可变数组表
create table department(
deptno number() primary key not null,
dname varchar2() not null,
workers worker_info_list
);
//插入数据
insert into department(deptno,dname,workers)
values( ,'后勤部',
worker_info_list(
worker_info(,'dustin','F'),
worker_info(,'kevin','F'),
worker_info(,'allen','M')
)
);
--------------------------------------------------------
数据库设计范式(了解):
.第一范式(确保每列保持原子性)
.第二范式(确保表中的每列都和主键相关)
.第三范式(确保每列都和主键列直接相关,而不是间接相关)
--------------------------------------------------------
数据库设计工具(重点):
powerDesigner工具的使用
Oracle学习系列7的更多相关文章
- Oracle学习系列1-7
Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...
- Oracle学习系列6
Oracle学习系列6 ************************************************************************************ 删除约 ...
- Oracle学习系列5
Oracle学习系列5 ************************************************************************************ ,掌握 ...
- Oracle学习系列4
Oracle学习系列4 ************************************************************************************ 数据库 ...
- Oracle学习系列3
Oracle学习系列3 ************************************************************************************ 多表查 ...
- Oracle学习系列1
两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 300 ; set pag ...
- oracle学习系列之四 (视图)
视图视图是数据库中特有的对象.视图用于存储查询,但不会存储数据(物化视图除外).这是视图和数据表的重要区别.可以利用视图进行查询,插入,更新和删除数据.Oracle有如下四种视图(关系视图,内嵌视图, ...
- oracle学习系列之三 (约束)
主键约束:外键约束:唯一性约束:检查约束:默认值约束 -——————五大约束 一. 主键约束: --创建表的主键约束 create table student (student_id number ...
- Oracle 学习系列之二(会话与事务级临时表和dual表 )
一. 会话临时表 --创建会话临时表create global temporary table tmp_user_session(user_id int, user_name varchar2(20) ...
随机推荐
- c语言文件复制
#include<stdio.h> #include<stdlib.h> void main(void) { // locate ], outfile[]; gets(infi ...
- ie兼容问题整理
1.连续发请求问题 * jquery(document).ready(function(){}) * 连续发请求ie8出问题,被拦截问题,url后边加时间戳 * 例 url : url+ ...
- 整合Spring Data JPA与Spring MVC: 分页和排序
之前我们学习了如何使用Jpa访问关系型数据库.比较完整Spring MVC和JPA教程请见Spring Data JPA实战入门,Spring MVC实战入门. 通过Jpa大大简化了我们对数据库的开发 ...
- Android各组件/控件间通信利器之EventBus
实际项目开发过程中,经常遇到如下场景:不同的应用程序组件的控件间具有一定的相互关联性,其中用户对后者进行的某种操作会引起前者的相应改变.举一个具体的场景:以糗事百科为例,在糗事列表页和详情页页,对于每 ...
- 解决Jenkins打不开浏览器问题
参考:http://blog.csdn.net/achang21/article/details/45096003 1.控制面板禁用掉jenkins服务 2.java -jar jenkins.war ...
- CSS权重及样式优先级问题
CSS权重值计算 一条样式规则的整体权重值包含四个独立的部分:[A, B, C, D]; (1) A 表示内联样式(写在标签的style属性中),只有 1 或者 0 两个值:对于内联样式,由于没有选择 ...
- Tomcat下使用war包发布项目
Tomcat下使用war包发布项目 转自<Tomcat下使用war包发布项目 >,地址:http://blog.csdn.net/wy818/article/details/7240294 ...
- 学完了js的知识,一起分享总结知识点
又一个知识点学完了,到了总结学习效果和知识总结的时间了.js这个编程语言相对于html和css的逻辑性要强一些,也比较不容易上手.概念性的知识点不难理解,就是实际的操作并不容易,需要通过学习和借鉴案列 ...
- 响应式注意要添加“视口”约束标记---viewport
视口:我们试图在iPhone中输出屏幕宽度,你会发现屏幕宽度是980,却和PC屏幕差不多大.原因是苹果主导的这些手机厂商,为了使用户获得完整web体验,很多设备都会欺骗浏览器返回一个数值较大的“视口” ...
- git中Member设置为Developer也可以的
之前说Member至少要设置为master,或者owner才行,昨天发现依然可以设置为developer. 因为有个位置可以设置Developers can push,√上就可以了. 比如,我不希望大 ...