- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个分类网站。我正在使用 SOLR 来索引和存储数据。然后我还有一个 MySQL 数据库,其中包含一些关于我不存储或索引的分类的更多信息。
现在,我有一个非常规范化的数据库,其中包含 4 个表。
每当在网站上搜索广告时,SOLR 都会进行搜索并返回一个 ID_numbers 数组,然后用于查询 mysql。所以 solr 返回 id:s,然后用于从 mysql 数据库中获取所有具有这些 id:s 的广告。
现在,我的表之间的所有 JOIN 和关系让我很头疼。
除了易于维护之外,拥有规范化数据库还能得到什么?
我能告诉你吗,将所有信息存储到一个包含大约 50 列的表中。
因此,为了找到一个广告并展示它,而不是这样:
SELECT
category_option.option_name,
option_values.value
FROM classified, category_option, option_values
WHERE classified.classified_id=?id
AND classified.cat_id=category_options.cat_id
AND option_values.option_id=category_options.option_id
我可以用这个:
SELECT * FROM table_name WHERE classified_id = $classified_id
最后一个不是更快吗?还是规范化的数据库执行得更快?
谢谢
最佳答案
我建议不要在您的情况下进行非规范化。随着您更多地使用连接,您会更好地使用连接,并且它们开始在您的脑海中变得更加清晰,并且易于维护对 future 来说是一个很好的好处。
Here是关于规范化(和非规范化)的一个很好的链接。 Here这是一个关于非规范化的问题。一个答案建议使用连接创建一个 View 以获取您需要的数据,并像您的 SELECT * FROM table_name WHERE classified_id = $classified_id
查询一样使用它。规范化的数据库可能会更慢,但您不太可能因此而想要反规范化。我希望这能提供一些帮助。
关于php - MySQL 头痛,我应该还是不应该?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2209502/
刚刚结束我的上一次冒险,现在我正在尝试映射更复杂的 URL 并疯狂地尝试使其按照 Spring 文档建议的方式工作。 同样,这些工具是: Java 1.6 Spring 3.2 MVC Tomcat
我找到了一些关于如何将用户构建的 .class 和 .jar 文件导入 JPype 的说明,但我似乎很难让任何东西正常工作。 有效方法:我可以导入标准的 java 内容并打印 HELLO WORLD
我已经浪费了几天时间试图追踪新添加的 Akka 传输加密中的间歇性错误。 注意:我已经尝试在服务器和客户端之一或两者上设置 setIssueHandshake(true) ,但它根本没有帮助。 我们的
我需要使用 PHP 从 PC 可靠地获取用户 ID。 我试过用 gethostbyaddr($_SERVER['REMOTE_ADDR']); 但这会返回 pc 的网络名称,而不是他们实际登录的名称。
我需要编写具有如下结构的程序: 父进程创建 fifo,然后 fork() child 1 从 stdin 读取消息并将其写入命名管道 (FIFO) 然后在父进程中我需要创建管道(未命名)和另一个 fo
GDB 开始让我头疼了。 GDB 的工作方式似乎有些奇怪。 obj/local/armeabi/包含项目中使用的所有未删除的 .so 文件的列表以及名为 objs-debug 的目录,其中包含一堆 .
我有一个分类网站。我正在使用 SOLR 来索引和存储数据。然后我还有一个 MySQL 数据库,其中包含一些关于我不存储或索引的分类的更多信息。 现在,我有一个非常规范化的数据库,其中包含 4 个表。
我正在使用 Javascript 对来自数据库的数据进行“mustache light”模板化。数据如下所示: As you can see in {{Figure 1-1}}, and again
我有一个 tableview,我创建了一个 segue 将它推送到另一个 View Controller 。时不时地,这个 segue 会在我不碰它的情况下中断,我可以保证。我什至没有编辑我放入的文件
我已经尝试找出一个问题大约 3 个小时了,我真的不明白为什么这个插件不起作用。有问题的插件称为 Blueberry,是一个使用 jQuery 的图像 slider 。 该插件在演示文件夹中完美运行(在
已更新! 我设法使用 PDT 获得动态收据,屏幕截图在这里:http://pastebin.com/4RcTdHKd这是从我的 pdt.php 生成的:http://pastebin.com/4RcT
所以让我首先说我已经遍历了我能找到的每一个问答,无论是在网站上还是在网站外,但我仍然碰壁。 我的程序: 我的程序所做的只是在与我的程序相同的目录中运行一个批处理文件。 代码是: try {
要么我错过了一些深藏在某些文档(Spring、Spring Boot、H2、HSQLDB、Derby、IntelliJ)中的核心概念,要么我已经盯着这个看太久了。 我有一个 Spring Boot 项
我的元素在 Chrome 中无法正常工作(鼠标悬停在图标上不起作用)。但是,firefox 显示正常。 http://i.stack.imgur.com/gpDHx.jpg Codepen 源代码 h
上下文与这个非常相似:Apple OSX OpenGL offline rendering with CoreGL . 我写了一个非常小的 C++/OpenGL 程序(我们实际上无法想象更简单),它应
我一直有类似的问题,但没有人解决我的问题。我正在 Web 服务器上运行一个 javascript 应用程序,该应用程序应该访问另一个子域中的 URL。浏览器是 Chrome 并且 CORS 总是在那里
我这辈子似乎无法以一种不会不时抛出随机错误的方式设置 rspec/capybara。我最常见的错误(但不一致)如下: An error occurred in an after hook Acti
我正在为一个 friend 开发一个网站,我在使用@font-face 实现字体时遇到了真正的麻烦 问题是字体确实与它创建的框内联。如果我制作一个 10 像素高的框,其中包含文本,文本会浮在它应该在的
我最近升级到 F24,现在在我的 R session 中,我无法加载一些包,sp。 reshape2、latex2exp、knitr 等。 我发现的最初问题是 F24 使用 libicu56,而这些包
经过八个多小时的搜索,我认输并为此创建了一个新问题。操作很简单,但我很难让它正常工作,似乎已经通过了所有其他解决方案。我需要两件事: 1.) 在整个文件中 PBS 的第一个匹配出现的行之前插入一行。它
我是一名优秀的程序员,十分优秀!