- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
毫无疑问,编写 SELECT * FROM viewCostumerAddress
比 SELECT c.id,c.name,a.id,a.fullAddress FROM customer c JOIN address a on 更简单直观a.id_costumer=c.id ORDER BY a.id,c.Priority
,但是当一群人告诉你“ View 的性能更好”而你的测试并没有显示你所做的这样的增益时?
我进行的所有测试都使用相同的 SQL Server 2014。数据集有大约 2kk 个客户端和 2.5kk 个地址。任何时候,服务器内存消耗都不会超过 60%。冷查询测试之后始终是完整的服务重启,以“强制清除”任何预编译查询和任何缓存信息。热查询的结果仅在每个查询/ View 被命中 200 次后才被记录,尽可能多地过滤不同的值。所有测试都在专用而非虚拟服务器(裸机)上进行了 1000 次。
然而,热查询的最终结果差异小于 1% (0.971%),冷查询的差异几乎为 0 (0.0024%)。
面对这些结果,我开始怀疑在现代 RDBMS 世界和“对象关系映射器”中,旧的性能提升声明是否仍然是从 View 而不是直接从表查询数据的有效理由?
PS:请尽量在您的回答中做到科学,提供测试方法(如果适用)和/或科学论文,或者在报告您 亲眼目睹。
最佳答案
如果您有一个不是索引 View 的普通 View ,则不会提高性能。这是因为,当您从 View 中选择时,SQL-Server 运行 T-SQL-Statement 就像没有 View 一样。
以下是我对观点的一些看法:
<强>1。 View 是安全层
我个人不希望任何人直接访问我的基表。在 View 中,我可以根据调用者的许可过滤掉行。在 SQL Server 2014 之前,您无法对表执行此操作。
<强>2。 View 正在返回一组特定的列
如果我必须更改基础表的模式,我可以以某种方式更改 View ,它返回与以前相同的列。如果您不使用 View 并且用户自己从基表中进行 SELECT,查询可能会失败。
<强>3。 View 正在节省开发时间
您不必一遍又一遍地编写相同的 T-SQL 语句。如果 T-SQL-Statement 中有错误怎么办?只需将它固定在一个地方,在 View 中。您可能不必更改应用程序或许多功能和存储过程。
<强>4。使用索引 View 加速 SELECTs
当您发现 View 中的 INNER JOIN 开销太大并且没有更多其他选项(如有用的索引或模式更改)时,您可以使用索引 View 来加速 SELECT。但是您可能会在 INSERT、UPDATE 和 DELETE 上降低性能,因为 View 的索引也必须更新。
关于mysql - View 性能增益在现代 RDBMS 中是否仍然相关,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32229384/
每次我尝试构建(执行完整的 Clean,然后构建)时,我都会在 Eclipse 的问题部分下弹出此错误消息。项目本身旁边还显示一个错误。 我已经尝试了同一问题的其他解决方案中包含的所有内容: 删除项目
我收到以下错误(注意:我使用的是 Netbeans): java.sql.SQLException: No suitable driver found for jdbc:derby://localho
例如 //somewhere struct IFace; struct Base { Base(IFace* iface): f(iface) { //wi
我试图通过 stringstream 将 double 变成字符串,但它不起作用。 std::string MatlabPlotter::getTimeVector( unsigned int xve
我正在尝试使用 AudioKit 框架中的音序器播放音频文件。 AudioKit.output = sampler AudioKit.start() sampler.enableMID
昨天我问了一个关于插入 Heroku 的问题。它不工作,然后突然开始工作。我什么都没改变。现在在一个新的应用程序上,我遇到了完全相同的问题。我决定包含我的整个 Gemfile,希望我可以继续没有这种令
我知道,这个topic已经是discussed许多times,所以直截了当。 这是ItemsSource的TabControl: Tabs = new ObservableCollection {
我有一个更新对象的函数,问题是当我从更新表单字段返回到详细 View 时,它初始化旧对象而不是更新后的对象。 我想在 CarService 而不是 app.js 中填充汽车列表 这是我的汽车服务:
在 resolution comments错误报告 12266 (“套接字连接错误导致资源泄漏”),Robert Ehteshamzadeh 写道 TClientSocket is deprecate
我最初发布了一个问题 here 我发现 JTextField 仅在 JScrollPane 存在时才调整大小。换句话说,我可以根据需要最小化和最大化它,直到出现滚动条(因为文本太多,无法放入窗口)。之
我读过关于 postion:absolute 的问题并尝试了几乎所有可能的解决方案。包括相对定位 div,将它们包装在相对定位的父级中等等,但它没有帮助。 我正在绘制一个表格,然后我将 div 放入其
我在这里发起了一个话题document.getElementById not working但看起来即使提出的建议都是有效的,我仍然有问题。 我有几个复选框。当我在这里查看页面源代码时,有。 docu
我正在做一些阅读,试图更好地理解按位运算符,然后偶然发现了 a helpful old blog post from 2012 ,其中指出 - 在随机正整数 x 的奇数测试中 - 在作者的计算机上评估
我正在尝试在 Eclipse Neon 中使用 aspectj 创建一个示例 maven 项目。然而,方面并没有编织/工作(参见下面的输出)。我尝试寻找很多原因和解决方案,但没有一个有效(请参阅下面的
无论我如何配置我的 appsettings.json 和 appsettings.Development.json,除非我手动添加 ConfigureLogging,否则我无法在信息消息下方记录任何内
我正在尝试使用 JQuery .get() 方法和 JavaScript for 循环来处理来自外部文件的一些数据。我已经在 stackoverflow 上阅读了有关闭包和回调返回值的内容几个小时,但
我正在使用 PHP 5.6 并且要打印一些东西,我必须编辑 php.ini 并包含 php_printer.dll 文件。但是 PHP 5.6 没有.dll 文件。 我要解决的问题: 我想将凭证打印机
我目前正在调试一个包含内存泄漏的大(非常大!)C# 应用程序。它主要使用 Winforms 作为 GUI,尽管一些控件是在 WPF 中制作的,并由 ElementHost 托管。直到现在,我发现许多内
[已解决] 看来 PHP MYADMIN 变量成功了。我将 wait_timeout 设置为 30 ,并将 Lock_wait_timeout 设置为 50 花了将近 6 个小时才恢复稳定,包括几次重
我读过几个关于该主题的讨论,有人说 qmake < 3.0 不正确支持该指令。我刚刚为 g++-64 重新安装了 Qt 5.9.1,但问题仍然存在。此外,我尝试过各种 mkspecs/xxx/xxx.
我是一名优秀的程序员,十分优秀!