我目前正在构建一个具有多种用户类型的 Web 应用程序,用户可以在其中参与多种事件类型。
我需要设计一个表格,将用户和事件之间的“喜欢”(赞成票、+1,等等)相关联。无论如何,我都不是 MySQL 方面的专家,所以我想避免在我的数据库设计中走上错误的道路,尤其是像这样的事情。
我想的是像下面这样的表格:
CREATE TABLE likes (
from_id int(11) NOT NULL,
from_type VARCHAR(100) NOT NULL,
to_id int(11) NULL,
to_type VARCHAR(100) NULL,
posted TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY(from_id, from_type, to_id, to_type),
INDEX(from_id, from_type),
INDEX(to_id, to_type)
)Engine=InnoDB;
随着系统规模的扩大,这会带来哪些性能问题?这些“点赞”将用于新闻提要,因此会有很多的读取和写入。
是否有我根本没有想到的更好的方法?
提前致谢!
最佳答案
您的 from_type 和 to_type 字段,如 VARCHAR(100),将是一个巨大的空间浪费,并且匹配它们的效率几乎不会像 VARCHAR(100)例如,匹配一个整数 from_type_id 和 to_type_id。当您向表中添加更多条目时,它们还会使维护索引的速度变慢。
如果您需要一个人类可读的类型名称,请制作另一个表格,列出它们以及它们的数字 ID。您可以将 id 设为该表的外键,尽管维护外键的完整性会产生一些相关成本。
大概不会有太多类型,至少与表中的行数相比,所以任何需要它们的进程都可以只读取该表一次,而不是询问数据库在每次读取时进行连接。
这些将减慢您的插入速度。您的目标应该是有足够的资源来满足您所有的读取查询,并尽可能多地处理您已经拥有的查询。
多列索引当然很有用,而且它们有一个很好的特性,即所有的前缀基本上都被索引了。也就是说,如果你在(a, b, c)上有一个索引,那么它也可以作为(a, b)上的一个索引,或者甚至只是在 a 上。 (MySQL 将以这种方式使用索引)。
这意味着,因为您在
上有一个索引(from_id, from_type, to_id, to_type)
那你还需要索引
(to_id, to_type)
但是你可以去掉索引
(from_id, from_type)
让数据库单独维护该索引只会减慢它的速度。
这也意味着您可能需要预先考虑一下索引中列的顺序。将 type 放在 id 之前可能更有意义,因为您更有可能查询数据库以获取特定类型的所有喜欢,而不是特定 id 的所有喜欢(对于每种类型).
如果您像这样构建索引:
(to_type, to_id, from_type, from_id)
(from_type, from_id)
然后您可以高效地搜索:
(from_type)(from_type, from_id)(to_type)的所有对象的所有喜欢>(to_type, to_id)(to_type, to_id, from_type )(to_type, to_id, from_type, from_id)关于mysql - 为类似 "Likes"的东西设计一个高度非规范化的表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9214721/
我正在尝试测试是否存在表单。我是Rails新手。我的new.html.erb_spec.rb文件的内容是:require'spec_helper'describe"messages/new.html.erb"doit"shouldrendertheform"dorender'/messages/new.html.erb'reponse.shouldhave_form_putting_to(@message)with_submit_buttonendendView本身,new.html.erb,有代码:当我运行rspec时,它失败了:1)messages/new.html.erbshou
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co
我好像记得Lua有类似Ruby的method_missing的东西。还是我记错了? 最佳答案 表的metatable的__index和__newindex可以用于与Ruby的method_missing相同的效果。 关于ruby-难道Lua没有和Ruby的method_missing相媲美的东西吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/7732154/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
我将应用程序升级到Rails4,一切正常。我可以登录并转到我的编辑页面。也更新了观点。使用标准View时,用户会更新。但是当我添加例如字段:name时,它不会在表单中更新。使用devise3.1.1和gem'protected_attributes'我需要在设备或数据库上运行某种更新命令吗?我也搜索过这个地方,找到了许多不同的解决方案,但没有一个会更新我的用户字段。我没有添加任何自定义字段。 最佳答案 如果您想允许额外的参数,您可以在ApplicationController中使用beforefilter,因为Rails4将参数