Oracle百问百答(一)
01. 如何查看 oracle 的版本信息?
02. 如何查看系统被锁的事务信息?
03 .怎么获取有哪些用户在使用数据库?
04. 数据表中的字段最大数是多少 ?
表或视图中的最大列数为 1000
05. 怎样查得数据库的 SID ?
select name from v$database; ,也可以直接查看 init.ora 文件
06. 如何查询表空间信息?
07. 如何统计两个表的记录总数 ?
08. 如何获取系统的当前日期,若天数大于 15 ,显示 1 ,否则显示 0 ?
09. drop user 和 drop user cascade 有什么区别?
drop user :仅仅是删除用户; drop user ×× cascade :会删除此用户名下的所有表和视图。
10
.
数据库表中没有设置级联删除
.
怎样用
SQL
语句实现,例如:
EMP
表中有字段
DEPT_NO
是外键
POS
表中有字段
DEPT_NO
是外键
DEPT
表中有字段
DEPT_NO,
如何实现删除
DEPT
表中数据时将
EMP
表
,POS
表中的相关数据也删除?
方法一:触发器解决
create or replace trigger delete_dept
before delete on DEPT
for each row
begin
delete from EMP where DEPT_NO = :old.DEPT_NO;
delete from POS where DEPT_NO = :old.DEPT_NO;
end;
方法二:修改从表的外键设置,改为“ on delete cascade ”模式
a)
先查询出
EMP
表和
POS
表中
外键的名称
(
如果已知道外键名,这一步可以省略
)
select CONSTRAINT_NAME,TABLE_NAME from user_constraints where CONSTRAINT_TYPE ='R' and TABLE_NAME in('EMP','POS');
b)
删除
EMP
表和
POS
表上的外键后
重新建立允许级联删除的外键模式
alter table EMP drop constraint
外键名
;
alter table POS drop constraint
外键名
;
alter table EMP add constraint
外键名
foreign key(DEPT_NO) references DEPT(DEPT_NO) on delete cascade;
alter table POS add constraint
外键名
foreign key(DEPT_NO) references DEPT(DEPT_NO) on delete cascade;