1.级联删除: -- 级联删除:裁员,公司倒闭 -- 级联删除(cascade),设置为null(setnull),放任不管(No action) -- cascade:(以一对多为例)如果删除多的一方数据,一的一方不受任何影响,但是如果删除一的一方的数据,多的一方所有对应数据全部被删除 select * from staff s inner join department d on d.id = s.department_id; delete from staff s where s.id =…
create trigger t_table_a on table_a for update,dalete begin if exists(select 1 from inserted) update table_b set 字段 =(select 字段 from innserted) where 字段=(select 字段 from delated) else delete table_b where 字段=(select 字段 from delated) go 级联删除还可以通过,可视化界面…
今天处理SQLServer级联删除遇到了很蛋疼的事. SQLServer 不支持表内自关联级联删除,而MySql和Oracle却支持. 貌似原因是SQLServer 会产生循环级联,就不给这样弄.所以很明确说:SQLServer 是不支持表内自关联级联删除. 那怎么办呢:只能用触发器呗 IF EXISTS (SELECT NAME FROM SYSOBJECTS WHERE NAME = 'tg_SysDelete' AND TYPE = 'TR') DROP TRIGGER tg_SysDel…
无意间看到一篇文章,觉得对于ORACLE的新手很实用,特转载,原文出处这里 说明:在创建数据库时输入的密码,是修改系统默认的密码,以system和sysman等系统默认身份登录时要输入的密码就是修改后的密码(创建数据库时输入的密码)如果要创建新的用户就必须以system或者sysman(这二者的权限最大)的身份登录后才可创建创建用户格式:create user 用户名 identified by 密码(例如:create user cht identified by cht;)创建完成后,必须分…
sql2000中三个表级联删除 create table a( id int primary key, Content varchar(50)) create table b( id int primary key, a_id int) create table c( id int primary key, b_id int) a,b,c三个表,b表的外键是a表的主键,c表的外键是b表的主键.删除a中数据,b和c中的相关数据也被删除,这时用触发器--建立a表的…
Oracle删除用户下所有对象的方法未必人人都会,下面就为您介绍两种常用的Oracle删除用户下所有对象的方法,希望对您学习Oracle删除用户方面能有所帮助. 方法1: drop user XXXX cascade; drop tablespace XXXX INCLUDING CONTENTS; 方法2: 写存储过程实现 Oracle删除用户下所有对象的方法未必人人都会,下面就为您介绍两种常用的Oracle删除用户下所有对象的方法,希望对您学习Oracle删除用户方面能有所帮助. 方…
/*以下代码是对emp表进行显示宽度设置 */col empno for 9999;col ename for a10;col job for a10;col mgr for 9999;col hiredate for a12;col sal for 9999;col comm for 9999;col deptno for 99;col tname for a12;set pagesize 50; //----------------------------------------------…