mysql级联删除怎么写 mysql设置级联删除

mysql怎么设置级联删除

这个在建表的时候就可以指定了

专注于为中小企业提供成都做网站、网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业池州免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

CREATE TABLE buildings (

building_no INT PRIMARY KEY AUTO_INCREMENT,

building_name VARCHAR(255) NOT NULL,

address VARCHAR(255) NOT NULL

);

CREATE TABLE rooms (

room_no INT PRIMARY KEY AUTO_INCREMENT,

room_name VARCHAR(255) NOT NULL,

building_no INT NOT NULL,

FOREIGN KEY (building_no)

REFERENCES buildings (building_no)

ON DELETE CASCADE

);

当执行

DELETE FROM buildings

WHERE

building_no = 2;的时候,rooms表中的building_no =2的记录都会被删掉。

mysql怎么实现多对多级联删除

delete t.*,t1.*,t2.* from tale_a t1, tale_a_b t, tale_b t2

where t1.id=t.aid and t.bid=t2.id and t1.你的删除条件

前提是 a表 a_b 表 b表 根据你的关联条件 inner join 能够查到内容

才会删除成功

t1.id=t.aid and t.bid=t2.id 替换成你的三个表的关联条件

MySQL写触发器,级联删除

我就不造你的 学生表和成绩表了.

用 test_main 表 和 test_sub  代替说明

-- 创建测试主表. ID 是主键.

CREATE TABLE test_main (

id      INT   NOT NULL,

value   VARCHAR(10),

PRIMARY KEY(id)  

);

-- 创建测试子表. 

CREATE TABLE test_sub (

id      INT  NOT NULL,

main_id INT ,

value   VARCHAR(10),

PRIMARY KEY(id)  

);

-- 插入测试主表数据.

INSERT INTO test_main(id, value) VALUES (1, 'ONE');

INSERT INTO test_main(id, value) VALUES (2, 'TWO');

-- 插入测试子表数据.

INSERT INTO test_sub(id, main_id, value) VALUES (1, 1, 'ONEONE');

INSERT INTO test_sub(id, main_id, value) VALUES (2, 2, 'TWOTWO');

通过  DELETE CASCADE  外键约束的处理机制来处理

mysql ALTER TABLE test_sub

-   ADD CONSTRAINT main_id_cons

-   FOREIGN KEY (main_id)

-   REFERENCES  test_main(id)

-   ON DELETE CASCADE//

Query OK, 2 rows affected (0.16 sec)

Records: 2  Duplicates: 0  Warnings: 0

mysql DELETE FROM

-   test_main

- WHERE

-   id = 1;

- //

Query OK, 1 row affected (0.02 sec)

mysql SELECT

-   *

- FROM

-   test_sub;

- //

+----+---------+--------+

| id | main_id | value  |

+----+---------+--------+

|  2 |       2 | TWOTWO |

+----+---------+--------+

1 row in set (0.00 sec)

如果你非要使用触发器来处理, 那么下面是一个例子:

-- 创建测试主表. ID 是主键.

CREATE TABLE t_test_main (

id      INT   NOT NULL,

value   VARCHAR(10),

PRIMARY KEY(id)  

);

-- 创建测试子表. 

CREATE TABLE t_test_sub (

id      INT  NOT NULL,

main_id INT ,

value   VARCHAR(10),

PRIMARY KEY(id)  

);

-- 插入测试主表数据.

INSERT INTO t_test_main(id, value) VALUES (1, 'ONE');

INSERT INTO t_test_main(id, value) VALUES (2, 'TWO');

-- 插入测试子表数据.

INSERT INTO t_test_sub(id, main_id, value) VALUES (1, 1, 'ONEONE');

INSERT INTO t_test_sub(id, main_id, value) VALUES (2, 2, 'TWOTWO');

DELIMITER //

CREATE TRIGGER tr_t_test_main_Del

BEFORE DELETE ON t_test_main

FOR EACH ROW

BEGIN

DELETE FROM t_test_sub WHERE main_id = OLD.id;

END;

//

DELIMITER ;

mysql delete from  t_test_main  where id = 1;

Query OK, 1 row affected (0.01 sec)

mysql select * from t_test_sub;

+----+---------+--------+

| id | main_id | value  |

+----+---------+--------+

|  2 |       2 | TWOTWO |

+----+---------+--------+

1 row in set (0.00 sec)

mysql怎么设置外键为级联删除,级联更新

设定外键为级联删除就可以了。

alter table B add constraint fk_ID foreign key (ID) references A(ID) on delete cascade;

这样只需:delete from A where ID=nnnn; 就可以自动删除对应B表内容了。

通过外键无法实现同步更新。

mysql级联删除触发器

你的数据库访问层是不是用Hibernate的?如果是Hibernate的话,可以再hbm.xml文件里设置cascade=“delete”就可以进行级联操作了。

如果不是Hibernate,而是用JdBC的话,且使用触发器的话,就要按照MySQL的触发器的编写规范来写了,你的这个触发器像是Oracle的。

怎么写mysql数据库延迟级联删除命令

举例:

1、建筑表

CREATE

TABLE

buildings

(

building_no

INT

PRIMARY

KEY

AUTO_INCREMENT,

building_name

VARCHAR(255)

NOT

NULL,

address

VARCHAR(255)

NOT

NULL

);

2、房间表

CREATE

TABLE

rooms

(

room_no

INT

PRIMARY

KEY

AUTO_INCREMENT,

room_name

VARCHAR(255)

NOT

NULL,

building_no

INT

NOT

NULL,

FOREIGN

KEY

(building_no)

REFERENCES

buildings

(building_no)

ON

DELETE

CASCADE

//这里指定了级联删除

);

3、执行删除会把building_no=2的room记录都删除了

DELETE

FROM

buildings

WHERE

building_no

=

2;


名称栏目:mysql级联删除怎么写 mysql设置级联删除
转载来于:http://ybzwz.com/article/dooephi.html