设为首页 加入收藏

TOP

数据库约束和视图问题(四)
2014-11-24 00:34:13 来源: 作者: 【 】 浏览:25
Tags:数据库 约束 问题
_NAME VARCHAR2(20),
SALARY NUMBER(8,2) -->6000
)
alter table empck
add constraint ck_empck check(salary>6000)
--************************************************************************************
www.2cto.com
--删除约束
* 删除约束条件对于表和数据不会产生影响
* 删除约束emp_manager_fk
ALTER TABLE employees
DROP CONSTRAINT emp_manager_fk;
--删除ck_empck
alter table empck
drop constraint ck_empck
-- www.2cto.com ******************************************************************
--约束的应用案例:
create table F_ADDRESS
(
address_id number(6) primary key,
province_name varchar2(20),
city_name varchar2(20),
district_name varchar2(20),
street_name varchar2(20),
street_nbr varchar2(20),
detail varchar2(20),
postcode varchar2(10)
)
www.2cto.com
create table f_cust
(
cust_id number(6) primary key,
cust_name varchar(50),
address_id number(6),
state varchar(10)
)
alter table f_cust
add constraint fk_f_cust foreign key(address_id) references F_ADDRESS
(address_id)
alter table f_cust
add constraint ck_f_cust check(state in('在用','作废'))
--定义约束f_cust中 cust_name唯一
alter table f_cust
add constraint un_f_cust unique(cust_name)
--删除约束
alter table f_cust
drop constraint un_f_cust
www.2cto.com
--**************************************************************************************
--视图: --为sql语句起的别名 给予表之上的一个查询语句
--语法:
--在CREATE VIEW语句后加入子查询.
CREATE [OR REPLACE] VIEW view_name
[(alias[, alias]...)]
AS subquery
[WITH READ ONLY];
create or replace view v_emp
as
select * from employees
--查询视图
select * from v_emp;
--视图的作用
--* select 语句比较复杂
--* select语句在开发的程序中可能多次使用
--* 在程序中直接使用视图 select * from v_emp
create or replace view v_emp
as
select "EMPLOYEE_ID","FIRST_NAME","LAST_NAME","EMAIL","PHONE_NUMBER",
"HIRE_DATE","JOB_ID","SALARY","COMMISSION_PCT","MANAGER_ID",
"DEPARTMENT_ID" from employees
www.2cto.com
--描述视图的结构(命令行执行)
desc v_emp
describe v_emp
--创建复杂视图
create or replace view v_emp_dept
as
select d.department_name,min(salary) mins,max(salary) mass,avg(salary) avgs,
sum(salary) sums,count(salary) counts
from employees e,departments d
where e.department_id=d.department_id
group by d.department_name
--查询视图 www.2cto.com
select * from v_emp_dept
--通过视图插入数据到表中
create or replace view v_dept
as
select deptno,dname,loc from dept
--查询视图
select * from v_dept
--通过 v_dept视图插入数据到dept表中
insert into v_dept(deptno,dname,loc) values(89,'xxx','ss')
--通过设置WITH READ ONLY选项可以禁止对视图执行DML操作.
create or replace view v_dept
as
select deptno,dname,loc from dept
with read only
--删除视图 www.2cto.com
--删掉视图不会导致数据的丢失,因为视图是基于数据库的表之上的一个查询定义.
DROP VIEW view_name;
首页 上一页 1 2 3 4 下一页 尾页 4/4/4
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇内联视图、标量子查询、WITH子查.. 下一篇关于SQL函数效率的一些测试与思考

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: