Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/mongodb/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
将数据库结构从MySQL迁移到MongoDB_Mysql_Mongodb_Join_Nosql - Fatal编程技术网

将数据库结构从MySQL迁移到MongoDB

将数据库结构从MySQL迁移到MongoDB,mysql,mongodb,join,nosql,Mysql,Mongodb,Join,Nosql,我正在将我的应用程序数据库从MySQL迁移到NoSQL(MongoDB)。然而,对于如何构造MongoDB,我有点困惑 在我当前的MySQL设置中,我有两个表,一个用于用户,一个用于日历。每个用户和日历都有一个唯一的ID。每个用户条目都包含一个与该用户关联的日历ID列表。每个日历条目还包含创建它的用户的ID 我面临的问题是,我有两种情况:对于登录控制台,我必须快速向用户显示他/她创建的所有日历;对于前端网站,我需要显示所有可用的日历及其作者 在MySQL中,我会使用连接来快速查询这些数据。如何在

我正在将我的应用程序数据库从MySQL迁移到NoSQL(MongoDB)。然而,对于如何构造MongoDB,我有点困惑

在我当前的MySQL设置中,我有两个表,一个用于用户,一个用于日历。每个用户和日历都有一个唯一的ID。每个用户条目都包含一个与该用户关联的日历ID列表。每个日历条目还包含创建它的用户的ID

我面临的问题是,我有两种情况:对于登录控制台,我必须快速向用户显示他/她创建的所有日历;对于前端网站,我需要显示所有可用的日历及其作者


在MySQL中,我会使用连接来快速查询这些数据。如何在MongoDB(或任何NoSQL数据库)中实现相同的功能?

您几乎得出了结论。只有两个没有联接的选项

  • 非规范化(存储嵌入到用户文档中的日历)
  • 进行单独查询(首先加载用户,然后加载他的日历)
  • 这两种方法都有各自的优点和缺点,已经讨论过很多次了(试着在谷歌上搜索“mongodb嵌入或引用”)

    简而言之:嵌入使您能够更快地读取,引用使您能够更丰富地查询和更容易/更快地写入