- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 asp.net 开发一个分类网站,我的数据库是 mysql。请 MSSQL 用户我也需要你的支持。这是与特定数据库提供程序无关的数据库架构的问题。
我只是想从你这里得到一点澄清。
所以在这里,因为这是一个分类网站,您可以发布招聘广告、车辆广告、房地产广告等...
所以我有一个标题表来存储有关广告的常见详细信息。如标题、描述等。
CREATE TABLE `ad_header` (
`ad_header_id_pk` int(10) unsigned NOT NULL AUTO_INCREMENT,
`district_id_fk` tinyint(5) unsigned NOT NULL,
`district_name` varchar(50) DEFAULT NULL,
`city_id_fk` tinyint(5) unsigned DEFAULT NULL,
`city_name` varchar(50) DEFAULT NULL,
`category_id_fk` smallint(3) unsigned NOT NULL,
`sub_category_id_fk` smallint(3) unsigned DEFAULT NULL,
`title` varchar(100) NOT NULL,
`description` text NOT NULL,
...............
PRIMARY KEY (`ad_header_id_pk`),
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
因此,如果它是一个工作广告,我有另一个表来存储仅与工作广告相关的属性,如薪水、就业类型、工作时间
此外,如果是车辆广告,我有单独的表格来存储燃料类型、变速箱类型等...
所以我有 10 个类别。这些类别在十年内不会改变。所以现在我有这两种方法
1) One header table and 10 specific tables for to store each categories attributes
2) One header table and One attribute table that will hold all attributes of each and every classified groups. for those that are not relevant will hold NULL values
在性能和可扩展性方面,什么是最好的方法。
建分类网站的 friend 请指点一下。提前致谢
最佳答案
这个问题我不是很清楚,但是我可以给一些建议:
首先,如果您发现自己想要在单个列/单元格中存储带分隔符的值,则需要后退一步并创建一个新表来保存该信息。切勿将分隔数据存储在单个列中。
如果我对您的问题的理解正确,广告
有类别
,例如“工作”、“待售”、“车辆”、“房地产”等。Categories
应该有 Attributes
,其中属性可能是每个类别所特有的东西,例如车辆类别的“传输类型”或“里程”,或“平方英尺”或“年份”为房地产类别 build ”。
处理这种情况的正确方法不止一种。
如果主类别在某种程度上是固定的,那么合理的设计选择是为每个类别的属性创建一个单独的表,这样每个广告列表将有一个来自 ad_header
的记录,还有一个从该类别的特定 Attribute
表中记录。因此,车辆列表将有一个 ad_header
记录和一个 vehicle_attributes
记录。
如果类别更灵活,在这种情况下,拥有一个 CateogryAttributes
表也是一种合理的设计选择,它定义了每个类别使用的属性,以及一个 Ad_Listing_Attributes
表,其中包含每个列表的属性数据,其中包括 CategoryAttributes
和 Ad_header
的外键。请注意,此表的模式有效地遵循实体/属性/值模式,该模式被广泛认为实际上更像是一种反模式。也就是说,在大多数情况下,这是要避免的事情。但是,如果您希望经常添加新类别,那么这里可能是您能做的最好的事情。
最后一个选择是将所有类别的属性放在一个大表中,并只填充您需要的内容。因此,车辆列表将只有一个 ad_header
记录,但记录中会有很多 NULL
列。在这种情况下,我会避免这种情况,因为您的理想场景需要某些类别的某些属性(即:NOT NULLABLE 列)但保留其他选项。
这是另一种情况,Postgresql 可能是更好的数据库选择。 Postgresql 有一种叫做表继承的东西,它是专门为解决这种情况而设计的,可以让你避免使用 EAV 表模式。
完全披露:在大多数情况下,我实际上是 Sql Server 专家,但 Postgresql 似乎确实更适合您。我的经验是 MySql 在 90 年代末和 00 年代初还不错,但从那以后就真的落后了。它今天继续流行,主要是因为早期的势头以及廉价托管可用性方面的一些优势,而不是任何真正的技术优点。
关于c# - 我应该为每个类别使用单独的表还是一个表来存储分类网站的所有属性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40467748/
我有这个网站,这个特定页面是安全的,但是当它回发时,它回发到一个不安全的页面。如何解决? 我正在使用 ASP.NET 向导。我有这个页面 - checkout.aspx,页面包含这个控件 checko
我有 2 个 azure 网站 - 两个独立的项目 我现在有 2 个网址: myazurewebsite.azurewebsites.net myazureblog.azurewebsites.net
我有 2 个 azure 网站 - 两个独立的项目 我现在有 2 个网址: myazurewebsite.azurewebsites.net myazureblog.azurewebsites.net
环境: 旧网站: React 托管在 Heroku URL( http://sameurl.com ) 新网站: Java 托管在 Heroku URL ( http://sameurl.com )
我已在 Windows Azure 上注册了一个测试帐户来对其进行测试。我构建了一个 Hello world ASP.NET Web 应用程序 + 数据库只是为了测试。 我安装了 Visual Stu
我有一个可以收集和显示各种测量值的产品(不会详细介绍)。正如人们所期望的那样,显示部分是一个数据库+建立在其之上的网站(使用 Symfony)。 但是,我们可能还会创建一个 API 来向第三方公开数据
这个问题在这里已经有了答案: Software keyboard resizes background image on Android (16 个答案) 关闭 8 年前。 我有一个类似的问题:So
这个问题似乎很常见,但我真的无法根据现有答案解决问题。 我有一个简单的 maven 项目,没有任何复杂的部署配置等,并且想在点击“mvn site”时生成一个 Maven CheckStyle 报告。
有没有人看过有关何时进行横向扩展与纵向扩展的最佳选择的任何分析或信息。什么时候一个比另一个更有意义。 目前,在标准模式和基本模式下,2 个小型实例的费用与 1 个中型实例的费用相同。 拥有 2 个小型
有没有办法找到 azure 网站何时停止? (我通过门户网站停止了网站,但我不记得是什么时候......) 我正在寻找一些日志,但没有找到任何有用的内容。 谢谢。 最佳答案 您拥有的最接近的是 azu
我目前在 Azure VM 的 IIS 中拥有一个网站。我已将该站点复制到 2 个可用区域中的 2 个虚拟机上。 这可以保护网站免遭停机。 我需要为高负载时刻实现一些可扩展性。这似乎就是创建音阶集的目
我有一个托管在 Azure 上的网站 ( http://mike-ward.azurewebsites.net/ )。我从 Azure 门户设置了一个指向(引用?)我的网站的 Azure CDN。根据
我有一个 Azure 网站(不是 Web 角色),有 2 个槽:生产和暂存。 我只想为生产插槽启用 CDN,而不是为登台启用,问题是我找不到识别主机插槽的方法。 RoleEnvironment 不可用
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等建议的问题。您可以编辑问题,以便可以用事实和引用来回答它。 4年前关
我们正在考虑将一些网站从 Azure 云服务迁移到 Azure 网站(事情似乎就是这样进行的)。显然,我们被明确告知云服务不会保留文件系统状态,因为它们会在机器故障时重新部署。 我假设网站是基于 Bl
我有一个 Azure 网站,需要使用在 VM 上运行的 Elasticsearch 服务。 虽然我需要能够锁定对 Elasticsearch 的访问,以便只有 Azure 网站可以访问它,但我似乎无法
我有一个 azure 网站,位于 yis3.azurewebsites.net - 我已将其提升为“共享”网站,以便我可以使用自定义域。我拥有从 123-reg.co.uk 购买的域名 yorkshi
我正在使用 abcPDF 动态创建 PDF。 我想保存这些 PDF,以便客户随时检索。最简单的方法(也是我现在在当前服务器上所做的方法)是将完成的 PDF 保存到文件系统。 看来我一直坚持使用 blo
我们正在尝试了解 Windows Azure 管理 API 为 Azure 网站(而非 Webroles)返回的监控数据的复杂性 例如,下图描述了为 CPUTime 检索的数据点。它似乎表明,在晚上
看起来真的很愚蠢,因为我找不到它: 门户网站似乎不太直观,我如何为一个“网站”付费并在其中运行最多 500 个网站?我想当我通过单击左下角的加号添加“网站”时,我添加了整个虚拟机而不是子站点。如何仅添
我是一名优秀的程序员,十分优秀!