2个表结构如下:
dict表:
id (PK,bigint,not null),
kind (varchar(32),null),
name (varchar(32),null)dictBook表:
id (PK,bigint,not null),
kind (varchar(32),null),
Values (varchar(100),null)现在假如:
dict表中有记录如下:
id 、 kind 、name
1 、 sex 、性别
2 、 degree 、学历dictBook表中有记录如下:
id 、 kind 、values
1 、 sex 、男
2 、 sex 、女
3 、 degree 、本科
4 、 degree 、大专我不知道怎么设置表的关联,dictBook表中的kind关联的是dict表中的kind,
即当删除dict表中的sex时,dictBook表中的kind就会把所有sex的记录都删除。
请问各位大哥,这样要怎么做?
解决方案 »
- 关于sql读表问题
- 求sql(micro sqlserver)语句
- 請教一個簡單的SQL递归查詢問題~~謝謝了
- 有个问题求教一下,sql server级联更新是指被参考表更新以后会联动,还是指参考表更新以后会联动?还是both
- 本人昨天删除Sql server 2005 想用2008,但是在删除的时候可能误删了什么,结果重新安装出错了,求各位大神帮帮忙!
- 100万数据面对上万个站点,每个站点可以共用这100万数据且有自己独立的排序规则如何设计DB??
- 如何将一个大的数据库分成几个小的数据库
- 仓库进销存帐的过程写法
- 请教一个unique约束的写法
- 删除现有表,建一个同名表的SQL语句.
- 两表关联查询的charIndex问题
- 如何将文本文件导入SQL数据库表
create trigger trig_delete_dict on dict
for delete as
delete dictBook from deleted where dictBook.kind=deleted.kind
ON dict
AFTER delete
AS
BEGIN
declare @temp varchar(10)
select @temp = kind from deleted
delete from dictBook where kind = @temp END
(id bigint not null primary key,kind nvarchar(32),[name] varchar(32))
create table dictbook
(id bigint not null primary key,kind varchar(32),[values] varchar(100))insert into dict
select 1,'sex','性别'
union all
select 2,'degree','学历'insert into dictbook
select 1,'sex','男'
union all
select 2,'sex','女'
union all
select 3,'degree','本科'
union all
select 4,'degree','大专'create trigger tri_dele
on dict
for delete
as
begin
delete dictbook from dictbook b,deleted d where b.kind = d.kind
enddelete dict where id = 1select * from dict
select * from dictbookid kind name
-------------------- -------------------------------- --------------------------------
2 degree 学历(1 row(s) affected)id kind values
-------------------- -------------------------------- ----------------------------------------------------------------------------------------------------
3 degree 本科
4 degree 大专(2 row(s) affected)
呵呵!谢谢大家,
刚才上网找了一下,使用Hibernate的话会和触发器有冲突吧,
晕啊!现在不知道怎么做,没思路了啊!