- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我知道,关系数据库是一种数据库,其中一个表中的字段链接到其他表中的行,就像这样。
但我不明白这对我作为网络开发人员意味着什么!
据我所知,具有联接和嵌套选择的查询会降低性能(尤其是具有数十个联接的 drupal 样式查询)。更重要的是,对数据库的任何查询都是瓶颈,然后您有很多用户,您必须缓存每个选择请求。
如果缓存每个选择请求,最好缓存简单的请求而不是复杂的请求。您可以缓存“select * from tbl1 where id = 123”和“select * from tbl2 where id = 456”或“select * from tbl1, tbl2 where ...”,但是如果您选择第二种方式,您将需要缓存对象的每个组合 - 这并不酷。
好的,现在我们只使用非常简单的查询,例如“select * from tbl1 where id = 123”或“select id from tbl1 order by id limit 0, 30”并缓存它们(或者我们可以只缓存第一种查询,无论如何)。查询和简单的 INSERT、DELETE 和 UPDATE 都是我们需要的,也是我们使用的!
正如我们所见,所有的关系逻辑都在应用程序的主要语言中,而不是在 SQL 中。那么,为什么我们需要所有这些相关的东西呢?他们的意思是什么? “关系”类型有什么其他类型没有但又需要的东西?如果我们不使用关系特性,为什么每个人仍然使用 MySQL 或任何关系数据库,即使他关心性能?
这种类型的数据库已经成为一种标准。为什么?我没有任何线索。除了 GAE 中的 on,我几乎没听说过有人使用非关系数据库。
我错过了什么吗?
最佳答案
如果您想了解关系的含义,我推荐 C. J. Date 的书“SQL and Relational Theory ”。
在此上下文中的关系不指的是关系。它指的是关系,这基本上就是导致 relational model 的数学理论中所称的表格。 .
关系数据库之所以变得无处不在,是因为它们是组织数据的最通用解决方案,冗余最少。
使用非关系解决方案有充分的理由。他们通常非常好地解决数据管理的特定任务,但在其他领域却很薄弱。而 SQL 和关系数据库达成了妥协,充分解决了更大范围的问题,而弱点更少。
“The Next-Gen Databases”中列出了当前可用的不基于关系模型的其他技术。
关于relational-database - 'relational' 中的 'relational database' 对我们意味着什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1689867/
我在 OS X 中构建菜单栏项时找到了一些示例代码。它使用了单个 |我不确定它的实际含义。 (我想做的是在菜单项左键单击时调用一个函数,但在右键单击时显示菜单) 这是我的代码 //Get refere
为什么它在第 23 行抛出编译错误。'a' 是 Apple 类的对象,col 是包含 Apple 对象的列表,但它仍然是抛出下面提到的编译错误: 类型 Collection 中的方法 add(capt
我有一个类A,它扩展了抽象类B。 让B有一个 protected 字段值 我想在 A 中使用这个字段。如果 A 没有 value,我可以编写 this.value 从 B 获取它。 与super.va
DBLint 用于检查数据库状态。有46条规则。在 www.dblint.org 上对每条规则都有一些简单的解释,但对规则 31 的描述如下: 定义的主键不是最小键:主键是最小的 super 键。如果
var aa: (()?) = (john.residence?.address = someAddress) var bb: ()? = john.residence?.printNumberOfR
我对 jquery 的可重用插件有点陌生。我已经多次遇到这段代码,但无法弄清楚究竟发生了什么。 (function( $ ){ ... })( jQuery ); 谁能帮我解答一下吗? 最佳答案
这个问题已经有答案了: int foo (int argc, ...) vs int foo() vs int foo(void) in C (4 个回答) 已关闭 9 年前。 所以我最近在 Hack
typedef struct Element { struct Element *next; void *data; } Element; 在 pop 函数中,(!(elem = *s
数据加载两次...意味着 AsyncTask onPostExecute 加载相同的数据两次?我的 AsyncTask onPostExecute 运行两次它加载相同的数据...我正在运行异步任务以从
运行“yomeanjs”时,我无限期地挂起“这可能需要几分钟”。当我尝试运行 grunt 时,它失败了,与 npm start 相同。 我使用的是 Win 8.1,并安装了最新的 Node 和 Mon
我正在看 big nerd ranch 的“Android Programming”中的这个页面,我对下面的句子感到困惑。它声明“当 Activity 被隐藏时, Activity 对象不存在”。这让
是否 const vector意味着它的元素是const也一样? 在下面的代码中, v[0].set (1234);在 void g ( const vector & v )产生编译器错误 const
我是 xml 相关事物的新手 我无法理解: SelectNodes(@"//Form/*[. = 'on']"); 注:SelectNodes是 XmlNode 的函数.(与 XmlDocument
我想方便地控制命令行参数。因此我想使用 ShellLib。 我的代码是这样的: ... #include ... EFI_STATUS EFIAPI UefiMain ( EFI_HANDL
着眼于更正 Debian 上/etc/init.d/hostapd 中的一个问题。但是,我不知道这行代码是做什么的,也不知道它是如何工作的 [ -n "$DAEMON_CONF" ] || exit
有没有人遇到过类似我下图所示的情况? 我有一个变量 landingBools.didSlowPast40Knots(正如您从调试打印输出中看到的那样)为假,但出于某种原因,if 语句评估为真。 知道为
我设法使用 flexbox 和一些非常基本的 JavaScript 为自己构建了三个下拉菜单。 因为我不太了解,所以我使用了一个简单的函数三次,而不是使用参数、变量和其他东西。我将其称为丑陋的“蛮力”
这周刚开始学习 javascript。我有一个非常菜鸟的问题。 exports.displayName = (undefined: ?string); 在 React Native 中意味着什么? 这
我正在阅读有关 NaN here 的内容它说: A comparison with a NaN always returns an unordered result even when compari
编码格式:引入*表示“从头开始重复”。例子。输入-{a,b,a,b,c,a,b,a,b,c,d}可以写成{a,b,*,c,*,d}。输出:5;例如2:ABCABCE,输出- 5。 这里*表示从头开始重
我是一名优秀的程序员,十分优秀!