- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个大型、复杂的遗留关系数据库,其中包含我们的用户数据。我想构建一个应用程序,根据各种标准对用户群体进行分割(显示所有体重超过 200 磅且穿着红色衬衫的人)。查询将由预定义的参数化谓词组成(想想 outlook 或 gmail 中的消息规则 UI)。完全即席的查询将很少见。
由于遗留架构的复杂性,针对源数据构建 SQL 查询是不切实际的。
第一个天真的想法可能是将要用于分割的数据反规范化到 RDBMS 中的一个非常宽的表中:
id | hat size | shirt color | weight | ....123 | 7 | blue | 175 | 456 | 6 | red | 205 |
但这并不太吸引人,因为数据会很稀疏,而且列会经常变化(每周?)。在我的环境中,架构更改在逻辑上很困难。
我可以进一步将该表规范化为一个简单的键/值表,但在这一点上,NoSQL 变得很有趣。
所以这是我的问题:
像 MongoDB 或 CouchDB 这样的面向文档的数据库是否适合这种用例?
我没有大量数据(在假设的非规范化表中,有数百万行、300 列左右)。写入相当少(每天 10,000 次)。查询每天会发生几次,响应时间需要以秒为单位。
过去几天我一直在阅读 NoSQL 的各种方法,面向文档的数据库似乎最适合我。欢迎提出更好的方法。
奖励问题_文档数据库的好处是否值得将新技术引入我们的数据中心的开销?_
我的意思是,我可能可以用我们现有的关系数据库很好地满足性能要求,但我有兴趣涉足 NoSQL 领域,因为我还有其他应用程序在面向文档的数据库真正支付 -关闭,我想先尝试一个简单的应用程序。
最佳答案
我们最近开始将 NoSQL“混合”到我们的技术堆栈中,但我开始通过 Mongo 使用上限集合进行简单的日志记录,以了解该技术并确保它的健壮性,重要的是,确保以后使用 NoSQL 作为持久性时,应用程序代码才有意义。数据和对象的持久化方式将随着这一举措而改变,这也需要考虑在内。
几乎没有什么是传统方法无法完成的,而且您会确信它也会像您期望的那样工作。这是低风险的。但我也想在未来的其他项目中使用它,所以我试了一下。
对于任何新技术,直到它在您的语言领域得到证实,并且您可以证明自己对它感到满意之前,我建议您采取“婴儿步骤”并逐步完成您所描述规模的项目。
顺便问一下,您是否考虑过使用索引 View 来“规范化”您的数据并从中进行选择?只是一个想法。
希望对您有所帮助!
关于mongodb - 面向文档的数据库是否适合此用例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4621999/
我正在制作一个简单的程序来更改我的计算机背景。我在网上发现了一个stackoverflow问题,或多或少涵盖了我想做的事情。我现在可以成功地将我的墙纸更改为平铺、居中和从在线图像 URL 拉伸(str
是的,这是另一个每组最大的问题之一!我已经尝试了几天,试图解决这个问题,但无济于事。我也一直在寻找,但我什至不知道我是否在正确的地方寻找。问题的最简化版本如下。 我有 2 个表,一个是多对多表,另一个
我想解析一些数据,我有一个 BNF 语法来解析它。谁能推荐任何能够生成可在移动设备上使用的代码的语法编译器? 由于这是针对 JavaME 的,因此生成的代码必须是: 希望很小 对外来 Java 库的依
我有一个动物园时间序列对象,vels : 2011-05-01 00:00:00 7.52 2011-05-01 00:10:00 7.69 2011-05-01 00:20:00 7.67 2011
我想创建一个供小型制造公司使用的生产管理系统。该系统将允许记录设备制造的不同阶段。要求如下: 1.非基于浏览器的界面。需要基于 Swing 或 AWT 的东西。虽然我了解实现基于浏览器的解决方案的便利
是否有任何 java 或 clojure 邮件库可以实现 lamson 的功能?特别是lamson的邮件路由功能非常酷http://verpa.wordpress.com/2010/11/13/mak
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我正在致力于缩小和丑化我的 javascript 文件。我想知道合适的尺寸是多大。如果我将所有js文件合并成一个文件(经过缩小和丑化),它会大于1mb。我想,最好将它们分成 2-3 个文件(每个文件
我是 Java 新手。 我想在 GridPane 中放置一个 TextArea。我在过去几个小时内尝试了此操作,结果如下: 如您所见,TextArea 比我的 Gridpane 大得多。这是我的代码:
sklearn 中的 fit() 方法似乎在同一界面中服务于不同的目的。 应用于训练集时,像这样: model.fit(X_train, y_train) fit() 用于学习稍后将在测试集上使用 p
我认为这是一个基本问题,但也许我混淆了这些概念。 假设我使用 R forecast 包中的函数 auto.arima() 将 ARIMA 模型拟合到时间序列。该模型假设方差不变。我如何获得该方差?是残
我使用 OSM 显示县的边界。它在大多数情况下工作得很好,但在某些情况下,县更大并且不适合 map 。 如何在开始渲染之前调整缩放级别? var map = L.map("mapCnty").setV
我有一个很长的标签,这是我的第一个标签,我想把它放在我的单元格中。这就是我所拥有的,但它不起作用。 我有一个自定义的 UITabelviewCell ,里面有几个标签。 -(CGFloat)table
假设我有一个包含 WCS header 的 FITS 文件,这样我就可以执行以下操作: #import healpy as hp #import astropy.io.fits as pyfits #
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭10 年前。 Improve
我们正在构建一个与其他系统有多个集成接触点的应用程序。我们有效地使用 Unity 来满足我们所有的依赖注入(inject)需求。整个业务层是用接口(interface)驱动的方法构建的,实际实现在应用
我得到了 MKMapView 和一些注释。我使用下一个代码来显示所有注释: NSArray *coordinates = [self.mapView valueForKeyPath:@"annotat
我在一家托管公司工作,我们经常收到安装、新域、滞后修复等方面的请求。为了大致了解仍然开放的内容,我决定制作一个非常简单的票务系统。我有一点 php 知识和一点 MySQL 知识。目前,我们将根据客户的
我想向我的 UITableView 添加背景图像,它适合 UI,还具有导航 Controller 和工具栏。在那种情况下,我没有找到适合 iPhone 和 iPad 不同屏幕的 tableview 的
我是一名优秀的程序员,十分优秀!