我对从零开始创建rails应用程序还是相当陌生的,我想知道如何最好地为高效的查询设置rails应用程序。
考虑一下这个场景。您正在构建一个使用mysql2作为数据库共享书籍的社交网站。您可以从两个模型开始:用户和author。两者都需要name属性;first_name、middle_name、last_name等。
创建一个名称模型是否更有效,其中名称将是它自己的单独表?
或者将名称属性添加到单独的用户和author中,其中属性保留为列?
发布于 2014-10-19 18:52:33
首先,您可以考虑使用PostgreSQL实现这一点--有很多,但性能是原因之一。
此外,您必须认为您构建的系统应该是可维护的。有一个单独的表作为名称可能是一个非常糟糕的想法。您是否计划为您在那个名称表中的所有模型添加名称?听起来很奇怪。你认为这样做能解决什么问题?
相反,我认为索引在检索关联时可以帮助您(https://tomafro.net/2009/08/using-indexes-in-rails-index-your-associations)。
我不能对你的数据模型给你更多的建议。这取决于要求和未来的意图。您要查询每个模型,然后检索关联吗?是否会有一种标记方法来处理同义词呢?
https://stackoverflow.com/questions/26453309
复制相似问题