- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 H2 数据库用于包含大量时间序列的环境数据。时间序列只是定期(例如每小时一次)记录在数据库中的传感器的测量值。
表中存储的数据:
CREATE TABLE hydr
(dt timestamp
,value double
,sensorid int)
我想对表进行范围查询,例如:
select * from hydr
where dt between '2010-01-01' and '2010-10-01'
为了提高性能,我想在 dt 列上构建聚集索引,但问题是,我还没有发现 H2 是否支持聚集索引。有人知道 H2 是否支持 聚集索引?
最佳答案
简答:表的主键必须是 BIGINT 类型:
CREATE TABLE hydr(dt bigint primary key, value double, sensorid int);
在这种情况下,表格是使用“dt”列组织的。这称为“聚集索引”。不支持 TIMESTAMP 数据类型,主要是因为它还包含纳秒。您可以做的是将 unix 时间戳(自 1970 年以来的毫秒数)存储为 BIGINT。
长答案:关于数据如何在 H2 内部存储的文档很差。我将在 H2 数据库的“性能”文档中添加以下部分。我希望这能解决问题(如果没有,请告诉我):
如何在内部存储数据
对于持久性数据库,如果创建表时使用 BIGINT、INT、SMALLINT、TINYINT 类型的单列主键,则表的数据以这种方式组织。这有时也称为“聚集索引”或“索引组织表”。
H2 内部以 b 树的形式存储表数据和索引。每个 b 树将条目存储为唯一键(一或多列)和数据(零或多列)的列表。表数据始终以“数据 b 树”的形式组织,具有 long 类型的单个列键。如果创建表时指定了 BIGINT、INT、SMALLINT、TINYINT 类型的单列主键,则该列作为数据 b-tree 的键。如果没有指定主键,如果主键列是另一种数据类型,或者主键包含多于一列,则在表中添加一个 BIGINT 类型的隐藏自增列,用作数据 b 树的键。表的所有其他列都存储在这个数据b-tree的数据区域内(大的BLOB、CLOB列除外,它们存储在外部)。
每增加一个索引,就会创建一个新的“索引 b-tree”。这个 b-tree 的 key 由索引列和数据 b-tree 的 key 组成。如果主键是在插入数据后创建的,或者主键包含多列,或者主键不是上面列出的数据类型,则将主键存储在新的索引 b-tree 中。
关于clustered-index - H2数据库: clustered indexes support,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3312857/
我收到多行错误,指出它有重复的类 Duplicate class android.support.v4.accessibilityservice.AccessibilityServiceInfoCom
我的项目昨天运行良好,今天却出现以下错误。请帮忙。 出了什么问题:无法解析配置“:app:debugCompileClasspath”的所有文件。 Could not find support-v4.
错误:配置项目“:app”时出现问题。 Could not find support-v4.jar (com.android.support:support-v4:24.0.0). Searched
我正在使用 react-native-webrtc 运行示例应用程序模块。我正在尝试在 android 中运行该应用程序,但出现这样的错误... * What went wrong: A probl
错误:配置项目“:app”时出现问题。 Could not find support-v4.jar (com.android.support:support-v4:24.0.0). Searched
我克隆了我的项目并使用 Android studio 打开,但构建失败并出现以下错误并且同一个项目在其他项目上运行良好。 出了什么问题:无法解析配置“:app:flavorUnsignedReleas
我正在运行示例应用程序......我正在使用 this模块.....但是我收到这样的错误... FAILURE: Build failed with an exception. * What went
我有一个 Ionic 项目,在升级到 OSx Mojave 后,出于某种原因不再构建。 该项目基于 Ionic 3 构建。 我有 Cordova CLI 7.0.0 当我运行时 ionic cordo
我有一个 Ionic 项目,在升级到 OSx Mojave 后,出于某种原因不再构建。 该项目基于 Ionic 3 构建。 我有 Cordova CLI 7.0.0 当我运行时 ionic cordo
添加 Android 平台(ionic cordova platform add android)后,我构建了我的 Ionic 项目(ionic cordova build android),但出现错
这个问题在这里已经有了答案: Manifest merger failed : Attribute application@appComponentFactory - Androidx (14 个答
关于我的 Gradle 文件中的以下“complie”: dependencies { compile 'com.android.support:support-v4:25.3.1' }
有些困惑。 我想更频繁地使用@supports 但是...我不关心浏览器如何看待它。希望您能说清楚,如果可以的话谢谢您。 如果浏览器本身不理解@supports,它如何计算@support 'not'
我刚刚升级到 Dart 2 和最新版本的 Flutter,现在我无法构建我的应用程序。我在互联网上环顾四周,但仍然不明白为什么会发生这种情况。 我得到的错误是: FAILURE: Build fail
我正在学习 Firebase,但由于以下错误而陷入困境: Error:Failed to resolve: com.android.support:customtabs:25.4.0 Error:Fa
我在构建本周时出于某种原因尝试使用Cordova进行项目时遇到问题: cordova build android gradle获取com.android.support:support alpha而不
对应的androidx是什么com.android.support:support-compat 的图书馆实现push notifications ? 他们说here它是 androidx 的一部分,
我正在尝试为我的应用设置插桩单元测试。并且我已根据以下开发者站点链接添加了依赖项。 https://developer.android.com/training/testing/unit-testin
当我想使用 Proguard 规则生成签名的 APK(发布)时,我收到了以下错误消息: Cannot find a version of 'com.android.support:support-an
这个问题在这里已经有了答案: Failed to resolve: com.android.support:appcompat-v7:26.0.0 (14 个答案) Failed to resolv
我是一名优秀的程序员,十分优秀!