Я занимаюсь разработкой подобного AddressBook проекта в VB.NET.Разрабатывая базу данных в SQL Server2005, я хочу следовать принципам нормализации и поддерживать степень ее нормализации на максимально высоком уровне.
Я использую следующие поля:
Create table AddressBook_Contact
(
Contact_ID int Primary Key,FirstName varchar(15),MiddleName varchar(15),LastName varchar(15),BirthDay datetime,HomeCountry varchar(20),HomeState varchar(20),HomeCity varchar(20),HomeMobile varchar(40),HomePhone varchar(40),HomeMobile varchar(40),HomeFax varchar(40),HomeZipCode varchar(10),HomeEmail varchar(50),HomeAddress text,
BusIndustry varchar(20),BusCompany varchar(20),BusWebsite varchar (30),BusCountry varchar(20),BusState varchar(20),BusCity varchar(20),BusMobile varchar(40),BusPhone varchar(40),BusFax varchar(40),BusZipCode varchar(10),BusEmail varchar(50),
BusAddress text,Note text
)
, если я создаю все поля в одной таблице ... Это против нормализации?и как это повлияет на стол, за исключением того, что оно станет медленным из-за значительного увеличения размера со временем.
Если я создаю отдельные таблицы для контактов (Biodata, HomeInfo, BusinessInfo)
create table AddressBook_Bio
(
BookID int Primary Key,
Title varchar(15),
FirstName varchar(15),
SecondName varchar(15),
LastName varchar(15),
BirthDay datetime,
Note text
)
create table AddressBook_Home
(
'My question in this case is should i declare BookID as foreign key or primary key to the table and why?'
FOREIGN KEY (BookID) REFERENCES AddressBook_ContactBio(BookID),
HCountry varchar(20),
HState varchar(20),
HCity varchar(20),
HMobile varchar(40),
HPhone varchar(40),
HFax varchar(40),
HZipCode varchar(10),
HEmail varchar(50),
HAddress text
)
create table AddressBook_Business
(
same issue as "AddressBook_Home"
)
Спасибо за заботу, чтобы выразить и поделиться своим мнением, знаниями.