将用户数据存储在单属性单列模型中,每个字段都有一个专用的列,具有几个优点。首先,它易于查询。可以直接对特定列执行查询,从而实现高效的数据检索。其次,这种方法保持了参照完整性和规范化,确保了数据一致性并减少了冗余。
将数据作为单个列中的JSON文档存储可能看起来很有吸引力,因为它具有灵活性,并且能够在无需修改模式的情况下适应新的字段。但是,此模型在查询方面存在挑战。要对特定字段执行查询,需要使用复杂的字符串操作技术,这可能会严重影响性能。
鉴于可搜索列的数量有限,可以考虑采用混合方法。用于查询的关键数据可以存储在单独的列中,而不太频繁搜索的数据可以存储在JSON列中。这种组合提供了这两种方法的优点,同时最大限度地减少了性能开销。
要使用单列JSON模型查询数据库中名为“foo”的用户,您需要使用表达式在meta JSON列中搜索。此表达式可能类似于:
<code>SELECT * FROM user_table WHERE JSON_SEARCH(meta, '$.name', 'foo') IS NOT NULL;</code>
在决定这两种方法之间时,请考虑应用程序的具体要求。如果查询性能、数据完整性和规范化是关键问题,则单属性单列模型仍然是首选。但是,如果灵活性以及适应不断发展的模式至关重要,则单列JSON模型可能适用。通过利用混合方法,您可以在这两个方面之间取得平衡,并根据数据的具体特征优化数据库设计。
以上是数据库中的 JSON:一列还是多列? 存储方法的比较的详细内容。更多信息请关注PHP中文网其他相关文章!