加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

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

发布时间:2020-12-12 16:40:35 所属栏目:MsSql教程 来源:网络整理
导读:在我的应用程序中,我有一个Customer类和一个Address类. Customer类有三个Address类的实例:customerAddress,deliveryAddress,invoiceAddress. 在数据库中反映这种结构的最佳方式是什么? 直接的方式是客户表和单独的地址表. 更为非规范化的方式将只是一个客户
在我的应用程序中,我有一个Customer类和一个Address类. Customer类有三个Address类的实例:customerAddress,deliveryAddress,invoiceAddress.

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

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

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

解决方法

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

CREATE TABLE Address
(
    ID int not null IDENTITY(1,Street varchar(120) not null
    -- etc
)

否则我会像这样建模:

CREATE TABLE Customer
(
    ID int not null IDENTITY(1,Name varchar(60) not null
    -- etc
)

CREATE TABLE Address
(
    ID int not null IDENTITY(1,CustomerID int not null
        CONSTRAINT FK_Customer_CustomerID FOREIGN KEY References Customer(ID),Street varchar(120) not null,AddressType int not null 
    -- etc
)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读