数据库 – 一个表中或单独表中的三个客户地址?

前端之家收集整理的这篇文章主要介绍了数据库 – 一个表中或单独表中的三个客户地址?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在我的应用程序中,我有一个Customer类和一个Address类. Customer类有三个Address类的实例:customerAddress,deliveryAddress,invoiceAddress.

数据库中反映这种结构的最佳方式是什么?

>直接的方式是客户表和单独的地址表.
>更为非规范化的方式将只是一个客户表,每个地址都有列(“街道”的示例:customer_street,delivery_street,invoice_street)

你有什么经验呢?这些方法有哪些优点和缺点?

解决方法

如果您是100%确定客户只会拥有您所描述的3个地址,那么这是可以的:
  1. CREATE TABLE Customer
  2. (
  3. ID int not null IDENTITY(1,1) PRIMARY KEY,Name varchar(60) not null,customerAddress int not null
  4. CONSTRAINT FK_Address1_AddressID FOREIGN KEY References Address(ID),deliveryAddress int null
  5. CONSTRAINT FK_Address2_AddressID FOREIGN KEY References Address(ID),invoiceAddress int null
  6. CONSTRAINT FK_Address3_AddressID FOREIGN KEY References Address(ID),-- etc
  7. )
  8.  
  9. CREATE TABLE Address
  10. (
  11. ID int not null IDENTITY(1,Street varchar(120) not null
  12. -- etc
  13. )

否则我会像这样建模:

  1. CREATE TABLE Customer
  2. (
  3. ID int not null IDENTITY(1,Name varchar(60) not null
  4. -- etc
  5. )
  6.  
  7. CREATE TABLE Address
  8. (
  9. ID int not null IDENTITY(1,CustomerID int not null
  10. CONSTRAINT FK_Customer_CustomerID FOREIGN KEY References Customer(ID),Street varchar(120) not null,AddressType int not null
  11. -- etc
  12. )

猜你在找的MsSQL相关文章