- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个数据库设计要求,它变得越来越复杂,我需要找出最佳的处理方法。
目前,我有“联系人”,也有“公司”。一个公司可以有多个联系人,但一个联系人只能属于一个公司。这形成了明显的 1:n 关系。但是,联系人不必有公司;主要是住宅/非商业客户(因此在前端称为“客户”)。这看起来变成了 0:n 关系。
contacts
表有一个指向 companies
表的 id
的简单外键来建立这种关系。
问题在于存储地址和电话号码。目前,contacts
表和companies
表均 分别存储一个地址和两个电话号码(静态列)。在大多数情况下,该软件只是简单地在两个表中镜像相同的数据; “公司”数据在可用时显示为普遍(也就是客户没有其公司的 id
“0”)。这会给最终用户带来一些困惑,并且也有严重的局限性。
我需要修改此设计以存储多个地址(帐单、送货地址等),当然还有我想要的尽可能多的电话号码。当然,这尤其适用于可能拥有多个设施和一个中央计费办公室的公司。
起初,我想为 companies
表中的地址制作 1:n;然而,contacts
也需要其潜在的独立数据。这通常会变得复杂,因为如前所述,联系人必须拥有公司,并且可以是独立的。公司可能出于计费目的需要一个地址主列表,然后联系人可能需要他们自己的地址列表以用于服务等。或者,公司可以简单地拥有所有地址(这可能是统计数据的最佳选择),然后联系人只有他们的主要地址或其他信息。
我怎样才能把所有这些放在一起?我是否有一个表用于所有联系人/公司地址,或者我是否需要单独的表(contacts_addresses
和 companies_addresses
)?我当然会对电话号码使用相同的策略。
我研究得越多,面对如此多的答案和方法,我就越感到困惑。到目前为止我的应用程序的领先者听起来像 this question .据此,我是否应该与 companies
表建立 1:n 关系,然后与 contacts
建立简单的 1:1 关系?如果是这种情况,我是否让 contacts
引用同一个表(并有一个与他们公司链接的地址的下拉列表供选择,以及创建新地址的选项),或者有contacts
表中的简单静态列?
最佳答案
个人和组织是抽象的合法政党的具体表现(这称为政党模型)。
Individual : Party
Organization : Party
可以将电子邮件地址、网址、电话号码、实际地址视为抽象地址的具体表示。
EmailAddress : Address
WebAddress : Address
PhoneNumber : Address
PhysicalAddress : Address
一个地址可以是空的。一个人可以有多个地址。多人可以共享一个地址。
因此Party和Address是多对多的关系:
Party -< ContactMethod >- Address
ContactMethod
有一个role
标签,例如“Work”、“Home”等。更专业的PhoneContactMethod
可能有一个Extension
列。
关于mysql - 客户/公司地址/电话号码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19695693/
以下是场景:我有一个可通过移动浏览器访问的网络应用程序。每当用户单击通过网络浏览器访问的应用程序页面中的链接时,我需要检测移动设备 IMEI 和 sim IMSI。这是为了跟踪具有相同 SIM 卡的同
场景如下:我有一个可通过移动浏览器访问的 Web 应用程序。每当用户单击可通过网络浏览器访问的我的应用程序页面中的链接时,我都需要检测移动设备的 IMEI 和 sim IMSI。这是为了跟踪具有相同
我需要在 Phonegap 为 Android 构建 HTML 移动 Web 应用程序中获取 IMEI 号码、手机号码、SIM 号码 最佳答案 你不能直接得到它们。 选项 1) 寻找一些插件,我不确定
我有一个输入框。它可能包含名称或数字。 如果输入至少有一个字母,我们将其作为名称处理,并且其长度应为 11 或更短。因此有效输入可能是 Bob、12Bob 或 Bob23。不允许有空格或其他字符,因此
我有这个要求:从客户表中 - 返回电话号码的前缀。我尝试使用字符串,将全名拆分为名字/姓氏,但它仅适用于数字。完整的nb格式为(258)1231456 最佳答案 SELECT '(258) 12314
我正在开发一个应用程序,用户必须使用手机键盘调用电话并输入验证号码。 我希望能够检测他们输入的数字是否正确。电话系统无法访问有效号码列表,但它会根据算法(如信用卡号码)验证号码。 以下是一些要求: 一
我有一张城市交通卡。我需要知道卡的援助(应用程序标识符)号码是多少。根据 EMV Book 1,我必须使用 List of AIDs 方法(第 141 页)。但是如何呢? 我还有一个 ACR122U
我想使用 javascript 分解数组中的 VIN,可能使用正则表达式,然后使用某种循环... 以下是读取 VIN 的方法: http://forum.cardekho.com/topic/600-
Here我找到了一个非常有用的答案,展示了如何使用 Whatsapp 从网站发送预填充的消息。 我们可以对 Telegram 做同样的事情吗? 最佳答案 您可以尝试使用以下方式打开 Telegram
我需要帮助完成这段代码,以便应用程序在收到推送通知时显示角标(Badge)编号,我可以收到推送通知,但应用程序上没有角标(Badge),这是代码 func application(_ applica
我正在使用 Twilio 进行入站调用,用户可以通过 Twilio-Number(从 Twilio 获得)调用应用程序并将被重定向到管理员。 现在,我们希望管理员使用相同的 Twilio 号码调用用户
C#/.NET 2.0 我需要解析一个字符串,其中包含街道名称和房屋编号的两个独立值。 in: "Streetname 1a" out: "streetname" "1a"
正如你们可能建议的那样,我正在创建一个带有语音命令的 SIRI。现在我确实想添加一个调用功能。例如我有这段代码: Intent call = new Intent(Intent.ACTION_DIAL
我想构建一个 android 应用程序,当设备第一次启动时,它会检测 IMEI 和其他设备信息,并检查是否有 SIM 卡。如果有 SIM 卡,它会发送短信包含特定号码的 IMEI 和其他设备信息。 我
我有这个对象: a = {"formData": { "total": "60.00", "tr0_RTN": "PZH", "tr0_amount": "10.00",
我正在制作一个测试工具,我有 imei 号码,但是否可以简单地或通过 NDK 更改 imei 号码。 谢谢 最佳答案 如何更改 IMEI 取决于硬件/系统,并且它是 - 至少在世界的(大部分)部分 -
我有一个表,其中有子项和父项,父项的 pid 为 0,子项的 pid 为父项的 id。我想选择父级及其子级数。 我的模型: function parent_child() {
抱歉,因为我从 android 开发跳到 IOS 开发,我想知道收到通知时是否有任何函数会触发?或者我应该如何处理通知? 这是我应用中的应用委托(delegate)。问题是每当收到消息时,如果应用程序
我正在开发应用程序,当它收到未接来电或来自手机的消息时自动发送消息。我的问题是当我从私有(private)号码收到未接来电或从私有(private)号码或服务器收到消息时(way2sms,160/2,
我想检查从联系人那里得到的电话号码是手机号码还是固定电话号码。我试过使用正则表达式,但一切都是徒劳的..任何帮助都将非常感激 最佳答案 要按手机号码和固定电话过滤联系人,您需要在数据库中有标准代码列表
我是一名优秀的程序员,十分优秀!