1.创建表:
create table IT_EMPLOYEES(
EMPLOYEE_ID NUMERIC(6) NOT NULL UNIQUE,
FIRST_NAME VARCHAR2(20),
LAST_NAME VARCHAR2(25) NOT NULL,
EMAIL VARCHAR2(25),
PHONE_NUMBER VARCHAR2(10),
JOB_ID VARCHAR2(10),
SALARY NUMBER(8,2),
MANAGER_ID NUMBER(6)
);
2.创建视图:
(1)
create view prog_employees_1
as
select employee_id,first_name,last_name,email,
phone_number,salary,manager_id from it_employees
where job_id='IT_PROG';
(2)
create view prog_employees_1
as
select employee_id,first_name,last_name,email,
phone_number,salary,manager_id from it_employees
where job_id='IT_PROG';
with check option;
(3)删除视图
drop view prog_employees;
3.创建索引
(1)Create 【unique】【cluster】INDEX<索引名> ON<表名>(<列名> <次序>)
例:
create index IT_LASTNAME ON IT_EMPLOYEES(LAST_NAME);
用户可以在查询频率最高的列上建立聚簇索引,由于聚簇索引是将索引和表记录放在一起存储,所以在一个基表上只能建立一个聚簇索引。在建立聚簇索引之后,由于更新索引列数据时会导致表中记录的物理顺序的变更,系统代价较高,因此对于经常更新的列不适宜建立聚簇索引。
(2)删除索引
Drop index <索引名>;
4.Alter
(1) 增加一列
alter table It_Employees add BIRTH_DATE DATE;
(2)修改字段
alter table It_Employees modify manager_id number(8);
(3)删除约束条件
alter table It_Employees drop unique(employee_id);
4.select / group by /having
注意:select子句后面只有两类表达式,统计函数和进行分组的列明。
Having 子句对分组的结果进一步筛选,having子句与分组有关,而where子句与单个行有关。
select deptno,avg(sal),sum(sal),max(sal),min(sal),count(sal) from emp group by deptno;
select deptno,avg(sal),sum(sal),max(sal),min(sal),count(sal),count(*) from emp group by deptno having avg(sal) > 2000;
5.内连接inner join /外连接(左left outer join/右外连接 right outer join/全外连接 full <outer> join )
区别:内连接进行多表查询时,返回的查询结果集中仅仅包含符合查询条件(where 条件和having条件)和连接条件的行。内连接消除了与另一个表中的任何行不匹配的行,而外连接扩展了内连接的结果集,除返回所有匹配的行外,还返回不匹配的行。
select empno,ename,dname from emp inner join dept on emp.deptno = dept.deptno where job='SALESMAN';
1 7499 ALLEN SALES
2 7654 MARTIN SALES
3 7844 TURNER SALES
4 7521 WARD SALES
5 5555 lipeng OPERATIONS
测试数据:deptno为null的
insert into
emp values(6666,'lipeng','SALESMAN',6666,to_date('2013-04-02','yyyy/mm/dd'),5000.00,1000.00,null);
select empno,ename,dname from emp left outer join dept on emp.deptno = dept.deptno where job='SALESMAN'
1 5555 lipeng OPERATIONS
2 6666 lipeng
3 7499 ALLEN SALES
4 7521 WARD SALES
5 7654 MARTIN SALES
6 7844 TURNER SALES
从结果可以看出:做外连接不仅包含连接相匹配的行,而且还包含左表emp中所有满足where限制的行,而不论是否与右表相匹配。
5.union /union all/intersect/minus
union 将集合中的重复记录滤除,而union all包含两个子结果集重复的行。
select ename,SAL from emp where ename like 'S%' OR ename like 'J%'
union all
select ename,SAL from emp where ename like 'J%' OR ename like 'C%';
6.子查询in/exists/比较运算符
(1)select empno,ename,deptno
from emp where deptno in (select deptno from dept where loc='CHICAGO');
执行顺序:先执行括号内的子查询,然后将查询到的deptno结果跟emp中的deptno进行比较,若列值存在于这些返回值中,则外层查询结果会在结果集中显示该行。
(2)select empno,ename from emp where exists (
select * from dept where emp.deptno = dept.deptno and loc='CHICAGO'
);
(3)查询emp表,将将薪资大于本职位平均薪资的雇员信息显示出来。
select empno,ename,sal,job from emp
where job='SALESMAN' and sal >(
select avg(sal) from emp where job='SALESMAN'
);
7.数据操纵 INSERT/UPDATE/DELETE/TRUNCATE
update emp
set sal =
(select avg(sal) from emp where job='SALESMAN')
where empno=6666;
commit;
delete from emp where empno=5555;
DELETE/TRUNCATE区别:
如果确定要删除表中所有记录时,建议使用TRUNCATE,因为TRUNCATE删除数据时要比DELETE快的多。但是TRUNCATE删除数据后,不能用rollback来恢复数据,但是delete可以用。
Reuse storage/drop storage
Truncate table emp reuse storage;
Reuse storage表示删除记录后保存记录占用的空间。
drop storage 表示删除记录后立刻回收记录占用的空间。
8.授权grant/回收revoke
grant select on emp to sup2db;
revoke select on emp from sup2db;
9.字符类函数
select ASCII('A') big_A,ASCII('a') small_a from dual;
select CHR(65),CHR(97) from dual;
select concat('oracle','11g') oraclename from dual;
select initcap('hello world') name from dual;
select replace('feelblue','blue','yellow') from dual;
日期函数:
select add_months(hiredate,1) from emp;
第七章 oracle数据库管理操作
一.增加安全性
解决的问题:例如,销售经理需要访问数据库中有关该部门员工的信息。但是该经理没有理由访问有关其它部门员工的信息。
(1)以系统管理员的身份进行登录:
conn sys/change_in_stall as sysdba;
(2)激活人力资源示例数据库账户,连接到HR示例数据库
Alter user hr identified by hr account unlock;
Conn hr/hr;
查看hr用户下面的所有表:
(1)连接到hr用户
(2)Select table_name from user_tables;
或者使用 Select * from tab;
(3)为销售经理创建用户ID,用户名salesmanger,密码sales,并将connect权限授予销售经理。
(4) Conn sys/change_in_stall;
grant connect to salesmanger identified by sales;
(4)定义一个查看员工编号和姓名的视图,将数据库中员工等信息隐藏起来。
create view emp_sales
as
select employee_id,first_name,last_name from hr.employees;
}
(5)授予salesmanger查看emp_sales视图的权限
grant select on emp_sales to salesmanger;
(6)让销售经理以用户salesmanger登录数据库后,销售经理可以查看员工的编号和姓名,但是不允许查看员工的工资信息,这样在一定程度保证了数据的安全性。
conn salesmanger/sales
select * from sys.emp_sales;
select * from sys.emp_sales;
二.隐藏数据的复杂性
现有一机场数据库,拥有pilotSkills表和hanger表,
其中表pilotSkills描述了飞行员和他们能够驾驶的飞机信息,表hanger描述了停在飞机棚中的飞机信息。
现在要求查询能够驾驶飞机棚中每一架飞机的飞行员的姓名。
--创建pilotSkills表
create table pilotSkills(
pilot char(15) not null,
plane char(15) not null,
primary key(pilot,plane)
);
create table hanger(
plane char(15) primary key
);
创建视图,实现“找出能够驾驶飞机棚中每一架飞机的飞行员的姓名”
Create view QualifiedPilots(pilot)
As
Select ps.pilot from pilotSkills ps,hanger h
Where ps.plane = h.plane
Group by ps.pilot
Having count(ps.plane) = (select count(plane) from hanger);
select pilot from QualifiedPilots;
三、实现记录的唯一性
--增加主键
Alter table stu add constrait c1 primary key(sno);
--删除主键约束
Alter table stu drop constrait c1;
--创建一个名为ind1的唯一索引
Create unique index ind1 on emp(empno);
当插入一条重复数据的时候会报错。
四.实现数据的完整性
Alter table student modify sname not null;
第八章 数据库用户管理
1.创建一个用户使其具有登陆,连接的系统权限
create user stu identified by stu;
grant create session to stu;
2.用户HR将Employees表的查询、查询、更改表的对象的权限授予stu,那么stu具有了对HR的employees表的select对象权限,但不具备其它对象权限。
conn hr/hr;
grant select,insert,update on employees to stu;
select first_name,last_name,job_id,salary from hr.employees where salary>15000;
3.授权角色
数据字典dba_roles可以了解数据库中全部的角色信息。
select * from dba_roles;
角色connect、resource和DBA主要用于数据库管理。对于数据库管理员分别授予Connnect、resources和DBA角色。
创建角色:
create role access_database;
Create role access_database identified by 123;
(2) 授权
grant create session,create table,create view to access_database;
(3)可将角色授予用户,使用户获得该角色所拥有的所有权限。
grant access_database to scott;
4.修改用户的默认角色
(1)设置用户的角色失效
Alter user scott default role none;
用户角色失效后,该用户中的权限将全部丢失。用户连接数据库权限create session存储于ACCESS_DATEBASE中,当该角色失效后,用户scott就不能登录到数据库中。
(2)设置用户角色生效
Alter user scott default role all;
(3)查看session_roles视图,确认会话所用的角色
connect stu/stu;
select * from session_roles;
结果:
ROLE
------------------------------
CONNECT
RESOURCE
(4)为当前用户启用ACCESS_DATABASE角色。
Set role access_database;
5.回收权限
*逐一回收
Connect sys/change_in_stall as sysdba;
(1)系统权限的回收
收回scott用户的select any dictionary系统权限。
Revoke select any dictionary from scott;
(2)对象权限的回收
Hr用户回收scott对employees表的select对象权限。
Connect hr/hr
Revoke select on employees from scott;
用户HR将基表Employees的所有权限从public用户回收。
Revoke all on employees from public;
6.删除角色
Drop role access_database;
删除用户:
Drop user stu;
7.使用数据库连接
是为了访问远程数据库而创建的数据库通信链路。
链接到指定的用户:
CREATE DATABASE LINK link_name CONNECT TO USER IDENTIFIED BY password USING server_name;
link_name:表示要链接到远程数据库名。
Server_name:表示远程数据库的服务名。
1.设置其它表空间初值
例如学生信息库,要把有关学生信息的一些表放到一个表空间中,如果有2000多名学生,则存储学生个人信息最多也不超过100MB的空间,但是为了保险,我们可以设置两个数据文件,每个数据文件的大小均设置为100MB
create Tablespace student_info
datafile 'C:\oracle\product\10.2.0\oradata\orcl\student01.dbf'size 100M, 'C:\oracle\product\10.2.0\oradata\orcl\student02.dbf'size 100M
default storage(
initial 10M
next 10M
minextents 1
maxextents 10
pctincrease 20
)
online;
说明:
Storage 指定表空间的存储参数,这些参数对于数据库的性能影响很大,选着时要慎重。
initial 10M:--表空间student_information初始空间大小为10MB
next 10M: -- 当初始区间填满后,分配第二个区间的大小为10MB
pctincrease 20:--当在填满时,按照20%的增长速率分配区间大小。
minextents 1:-- 初始为该表空间分配1个区间
maxextents 10: --最多为该表空间分配10个区间
2.空间充足的管理
(1)使用数据字典动态监视
这里使用的数据字典是dba_free_space和user_free_space,可以查看其内容来得到有关表空间的空间信息。
以system的身份登录:
select * from dba_free_space;
(2)向表空间增加数据文件
alter tablespace student_info
add datafile
'C:\oracle\product\10.2.0\oradata\orcl\student03.dbf'
size 2M;
注意:通过上述方法给表空间分配太多的空间并不好,因为这样做无疑造成较大空间的浪费。因此建议做好空间估计,并合理利用空间,无论是对减少资源浪费还是提高系统性能都有好处。
3.解决空间不足的方法
扩充数据库存储空间常用的方法有如下三种:
(1)增加SYSTEM表空间中数据文件的大小
(2)创建新的表空间
(3)创建新的数据文件
(1)增加SYSTEM表空间中数据文件的大小
数据库中的数据其实都是存储在数据文件中的,SYSTEM表空间的数据文件是在创建数据库的时候给定的,并且给其大小给定了一个初值。那么System表空间不够时就可以Alter DataBase命令动态的增加SYSTEM表空间数据文件的大小。
查11g
Alter DATABASE orcl
Datafile 'C:\oracle\product\10.2.0\oradata\orcl\system01.dbf'
resize 750M;
(2)创建新的表空间
表空间其实是一个逻辑概念,它所有数据和结构信息都存储在一个或者多个数据文件当中,当需要扩充数据库存储空间时,可以创建新的表空间并指定它的数据文件,系统就会划出一块磁盘空间给这个表空间.
注意:创建数据库时最好能创建几个私用的表空间,因为SYSTEM表空间是系统表空间,其中存储数据字典和数据库结构等重要信息,他是数据库运行的基础,若是把所有信息都存放在这个表空间里,一方面会迅速占满它的空间,另一方面也加大了出错的可能性。
1. Create tablespace 命令简介
Create tablespace 表空间名
Datafile{
文件名[autoextend {off | on next数值 maxsize数值}],
}
Mininum extend 数值
Logging | nologging
Default storage{...}
Online | offline
Permanent | temporary;
2.用create tablespace创建表空间
create tablespace test
datafile 'C:\oracle\product\10.2.0\oradata\orcl\test01.dbf' size 2M
default storage(initial 2M
next 2M
minextents 2
maxextents 10
pctincrease 20
)
online;
向表空间中增加数据文件使用的命令:
Alter tablespace 表空间名
Loggin | nologging
Add datafile{数据库文件名 [autoextend],...}
Rename datafile 原文件名 to 新文件名
Coalesce
Default storage
Mininum extend 数值
Online | offline [normal | temporary | immediate | for recover]
[begin | end] backup
Read only | write
Permanent | temporary
说明:
Add datafile:用于增加数据文件,可在联机或者是脱机下增加,但所增加的数据文件不能是其它表空间或者数据库已经使用的,它同样可带autoextend参数选项。
Coalesce:用于所有相连的空间范围合并到相邻较大的范围当中去,这一项不能被其它命令所指定。
[begin | end] backup:用于开始或者结束联机备份表空间的数据文件,在备份过程中用户可以继续访问该表空间,但备份过程中不能将表空间脱机,也不能关闭数据库。
Read only | write:其中Read only表示此表空间的内容是只读的,不能像其中写入任何数据,而read write则可以对此表空间的数据进行读写操作。
向表空间test中增加两个大小为10MB的数据文件
Alter tablespace test
Add datafile
'C:\oracle\product\10.2.0\oradata\orcl\test02.dbf size 10M' ;