0

这是在 3NF 中吗?

create table movies( 
  id numeric primary key not null default autoincrement,
  name varchar(50) not null, 
  release-date Date, 
  price numeric, 
  rating numeric,
  length numeric,
  description varchar(1500)
);

create table movies( 
  id numeric primary key, 
  name varchar(20) 
);

create table genre(
  name varchar(20) primary key
);

create table directors(
  id numeric primary key not null default autoincrement, 
  first-name varchar(32) not null, 
  last-name varchar(32) not null, 
  gender varchar(8), 
  dob Date, 
  biography varchar(1000)
);

create table movie-Star(
  id numeric primary key not null default autoincrement, 
  first-name varchar(20) not null, 
  last-name varchar(20) not null,
  gender varchar(8), 
  dob Date, 
  hometown varchar(20)
);

create table movies-cast(
  movie-id numeric references movies(id), 
  actor-id numeric references movie-Star(id), 
  role varchar(32), 
  primary key (movie-id, actor-id)
);

Create table Studio( 
  studio-id numeric references directors(id)
  Directer-name varchar(20) not null
  name varchar(20) primary key
);

create table directors(
  id numeric primary key not null default autoincrement, 
  first-name varchar(32) not null, 
  last-name varchar(32) not null, 
  gender varchar(8), 
  dob Date, 
  biography varchar(1000)
);
4

3 回答 3

0

如果所有都不能再次复制,则包含 3NF。确保不再有重复数据

于 2010-10-14T09:46:34.230 回答
0

它有e PK,所以它是1NF。它的PK不是复合的,所以它在2NF中。所有的列都只依赖于键,所以它在 3NF 中。除了PK之外没有其他密钥,所以它在BCNF中。

于 2010-10-14T10:02:05.757 回答
0

它看起来结构很好。我没有看到任何规范化问题。然而:

  • 电影和导演表被创建两次。
  • 流派表不用于任何事情(大概应该在电影中)。
  • 与工作室相同。
  • 目前的安排允许每个工作室只有一名导演。这可能应该是 A) 每个导演一个工作室(将 studio_id 列添加到 director)或更可能 B)工作室和导演之间的多对多关系(添加新的 studio_directors 表)。
  • 目前的安排没有将导演与电影联系起来。
  • 您可以考虑将 Director 和 Movie-Start 合并到一个名为 Talent 的表中。您有数据重复,其中明星也是导演。这是您设计中最大的标准化问题。
于 2010-10-14T17:04:29.463 回答