- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我想知道在关系数据库中将对象存储为序列化数据(例如 json)是否是一个好习惯。我知道这通常是一件坏事,我不打算广泛使用它,但我偶然发现了一个让我思考的案例。
所以,这是我的情况。我基本上是在构建一个移动订购系统,用于将元素从 A 点运送到 B 点。A 是起始地址,B 是目的地……两者都是用户当前的 GPS 坐标(以及街道名称、街道号码等可读数据) .
这些是要求:
因此,难题在于是为地址数据使用单独的表(列:id、街道、街道号码、纬度、经度...),还是简单地将地址存储为 JSON 字符串?
据我所知,JSON 的唯一缺点是必须对数据进行序列化/反序列化。由于它只有几个字段,因此不会产生太大影响。
另一方面,有一些我不喜欢单独表格的地方:
我想我不会用标准的关系方法出错并将地址存储在单独的表中,但我看不到它有任何真正的优势。
最佳答案
您确定永远不需要对地址数据进行任何查询/分析吗?
如果这是一个小的个人项目,这似乎很好。
但是,如果您需要更改任何属性,特别是如果这个项目不是完全由您决定的,那将是一个巨大的麻烦。我不会太担心“数百万行仅用于显示目的”——现代数据库系统针对存储大量行进行了优化,但不一定是非结构化数据。
因此,我强烈建议您采用久经考验的关系方法。
它可能有数百万行,仅用于显示目的:如果您担心用完自动递增的 ID,我敢打赌您希望进行大规模交付服务。您真的不想按 GPS 坐标分组吗?
如果所有内容都在一个表中,则更容易监控数据:我不认为这是真的。显然,如果所有数据都以一致的格式存储,就会出现这种情况。但是,每次都必须处理包含 JSON 的监控数据似乎是另一回事。
在显示有关订单的信息的任何地方都需要数据,因此我需要始终连接这 2 个表:如果这实际上更慢,公平点。但是,如果您只连接您关心的子表,我想连接会比 json 解析运行得更快。
极不可能,但从理论上讲,我可能会用完自动递增的 ID:请参阅 this question .不会发生的。
关于mysql - 将 "readonly"对象作为序列化数据存储在关系数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19967807/
我有一个只读的文本框,但想回发它的值。之前我将代码设置为: /asp:TextBox> 它不工作。我删除了 ReadOnly="true" 并在代码中添加了以下行 txtContractStartDa
一些背景 因此,我正在完成一个 Web 应用程序的一些增强功能,该应用程序可以对数据进行一些自动插值。用户填写了一些文本框,它们之间的其他文本框具有自动计算的值。接收自动计算值的文本框必须是只读的,以
我刚刚审查了一些代码,注意到有人将成员标记为 readonly private。这与 private readonly 有任何不同吗? 例子: readonly private MyClass myI
我刚刚被告知 readonly ref readonly 现在是有效的 C#,我可以清楚地看到它作为面试问题的用途,但除此之外,它什么时候可以用于现实生活? 最佳答案 当您有一个可变结构时,您希望其中
当我使用以下命令运行我的Reactjs + ElectronJS应用程序时,它可以很好地运行: yarn start 。 当我尝试使用以下命令生成该错误时: yarn build 。 我不明白这是怎么
例子1 private const string _DefaultIconPath = _IconsPath + "default.ico"; private const string _IconsP
尝试访问 RecipeList.js 和 Recipe.js 的 .props 时出现语法错误。 这是 Recipe.js 的代码示例: import React, {Component} from
我是 Vue 新手。我正在尝试开发一个聊天应用程序,其中好友列表将显示在左侧菜单上,聊天框将显示在正文中。我正在使用 ajax 调用加载好友列表,并根据好友 ID 路由到聊天框。这是代码示例。
我是 SharePoint 的初学者开发人员,我一直使用 Google map 。我安装了 google-maps-react 但有一个错误告诉我。我不知道如何解决它...请让我知道这个解决方案...
我不确定我是否理解 IE 在我正在使用的脚本中的行为。这是我正在使用的脚本的一部分,它似乎在 Chrome 中运行良好 $(document).keydown(function (event) {
我对原生 react 完全陌生。 我有以下组件: 播放列表: export default class Playlists extends Component { playlists = [
所以我正在使用 MVC3 生成一个文本区域元素。我使用以下标记生成我的元素: model.Description, new { value=Model.Description, @class="re
我有一个从 php 文件创建的表单,以及一个具有只读属性的文本字段,在单击编辑按钮时(编辑按钮也在创建输入字段期间创建),我希望所述字段是可编辑,我该怎么做? value= readOnly>
我正在尝试输入组件的属性并同时使用 URL 参数。我收到以下错误: Property 'match' does not exist on type 'Readonly & Readonly' 这是我的
这个问题在这里已经有了答案: Array.IsReadOnly inconsistent depending on interface implementation (4 个答案) 关闭 8 年前。
根据文档 ( here ),Google 提供了一些相同的范围: https://www.googleapis.com/auth/calendar读/写访问到日历 https://www.google
我使用的是JAWS v2023.2212.23,我有一个div容器,里面有段落和列表。我的要求是,当我专注于div容器时,JAWS应该读取整个块。。对于演示角色,它将只读第一段。。谁能帮我理解所有咏叹
我有一个单选按钮控件,其中有两个项目。 Add A Delete D 我想在条件 X 上仅禁
一、Reactive api 下面我们可以一个例子 如图所示,当我们点击button按钮的时候,是没有响应式效果的,此时我们需要reactive api。 那么这是什么原因呢?为什么就可以变成响应式的
我正在寻找一种在ng-readonly语句中调节ng-if的方法..我尝试了几种方法,这是我的最新建议。 ng-if="note.owner_image === user.image " ng-re
我是一名优秀的程序员,十分优秀!