This is an automated email from the ASF dual-hosted git repository.
jackietien pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/iotdb.git
The following commit(s) were added to refs/heads/master by this push:
new 324275f2759 Fix NPE after keeping all null rows in memtable
324275f2759 is described below
commit 324275f2759e5e6514c742e06968aef09bf12aca
Author: Jackie Tien <[email protected]>
AuthorDate: Wed Sep 18 19:27:22 2024 +0800
Fix NPE after keeping all null rows in memtable
---
.../db/it/aligned/IoTDBAlignedLastQueryIT.java | 113 +++++++++++++++++++++
.../db/utils/datastructure/AlignedTVList.java | 6 +-
2 files changed, 118 insertions(+), 1 deletion(-)
diff --git
a/integration-test/src/test/java/org/apache/iotdb/db/it/aligned/IoTDBAlignedLastQueryIT.java
b/integration-test/src/test/java/org/apache/iotdb/db/it/aligned/IoTDBAlignedLastQueryIT.java
index d8a04e08f19..7d00df8fb6b 100644
---
a/integration-test/src/test/java/org/apache/iotdb/db/it/aligned/IoTDBAlignedLastQueryIT.java
+++
b/integration-test/src/test/java/org/apache/iotdb/db/it/aligned/IoTDBAlignedLastQueryIT.java
@@ -340,4 +340,117 @@ public class IoTDBAlignedLastQueryIT {
selectSomeAlignedLastWithTimeFilterTest();
selectSomeAlignedAndNonAlignedLastWithTimeFilterTest();
}
+
+ @Test
+ public void testNullInMemtable() {
+ String[] sqls =
+ new String[] {
+ "create aligned timeseries root.ln_1.tb_6141(fengjituichu_BOOLEAN
BOOLEAN encoding=RLE,`chushuiNH4-N_DOUBLE` DOUBLE
encoding=GORILLA,mochanshuizhuangtai_BOOLEAN BOOLEAN encoding=RLE,11_TEXT TEXT
encoding=PLAIN,chanshuijianxieyunxingshijianshezhi_DOUBLE DOUBLE
encoding=GORILLA,wenben_TEXT TEXT encoding=PLAIN, fengjitouru_BOOLEAN BOOLEAN
encoding=RLE,meiju_INT32 INT32 encoding=RLE,chushuiTP_DOUBLE DOUBLE
encoding=GORILLA,shuiguanliusu_DOUBLE DOUBLE encoding=GORILLA,CO2_DOUBLE DOU
[...]
+ "alter timeseries root.ln_1.tb_6141.fengjituichu_BOOLEAN upsert
alias=fengjituichu;",
+ "alter timeseries root.ln_1.tb_6141.shuiguanliusu_DOUBLE upsert
alias=shuiguanliusu;",
+ "alter timeseries root.ln_1.tb_6141.CO2_DOUBLE upsert alias=CO2;",
+ "alter timeseries root.ln_1.tb_6141.fengjitouru_BOOLEAN upsert
alias=fengjitouru;",
+ "alter timeseries
root.ln_1.tb_6141.chanshuijianxieyunxingshijianshezhi_DOUBLE upsert
alias=chanshuijianxieyunxingshijianshezhi;",
+ "alter timeseries root.ln_1.tb_6141.mochanshuizhuangtai_BOOLEAN
upsert alias=mochanshuizhuangtai;",
+ "alter timeseries root.ln_1.tb_6141.meiju_INT32 upsert alias=meiju;",
+ "alter timeseries root.ln_1.tb_6141.chushuiTP_DOUBLE upsert
alias=chushuiTP;",
+ "alter timeseries root.ln_1.tb_6141.wenben_TEXT upsert
alias=wenben;",
+ "alter timeseries root.ln_1.tb_6141.`chushuiNH4-N_DOUBLE` upsert
alias=`chushuiNH4-N`;",
+ "alter timeseries root.ln_1.tb_6141.gongnengma_DOUBLE upsert
alias=gongnengma;",
+ "alter timeseries root.ln_1.tb_6141.11_TEXT upsert alias=`11`;",
+ "alter timeseries root.ln_1.tb_6141.`kaiguanliang-yunxing_BOOLEAN`
upsert alias=`kaiguanliang-yunxing`;",
+ "insert into
root.ln_1.tb_6141(time,chanshuijianxieyunxingshijianshezhi_DOUBLE) aligned
values(1679365910000,10.0);",
+ "insert into root.ln_1.tb_6141(time,chushuiTP_DOUBLE) aligned
values(1679365910000,15.0);",
+ "insert into root.ln_1.tb_6141(time,gongnengma_DOUBLE) aligned
values(1679477545000,2.0);",
+ "insert into root.ln_1.tb_6141(time,wenben_TEXT) aligned
values(1675995566000,52);",
+ "insert into root.ln_1.tb_6141(time,meiju_INT32) aligned
values(1675995566000,2);",
+ "insert into root.ln_1.tb_6141(time,shuiguanliusu_DOUBLE) aligned
values(1679365910000,15.0);",
+ "insert into root.ln_1.tb_6141(time,mochanshuizhuangtai_BOOLEAN)
aligned values(1677033625000,true);",
+ "insert into root.ln_1.tb_6141(time,fengjitouru_BOOLEAN) aligned
values(1675995566000,true);",
+ "insert into root.ln_1.tb_6141(time,fengjituichu_BOOLEAN) aligned
values(1675995566000,false);",
+ "insert into root.ln_1.tb_6141(time,11_TEXT) aligned
values(1679365910000,13);",
+ "insert into root.ln_1.tb_6141(time,CO2_DOUBLE) aligned
values(1679365910000,12.0);",
+ "insert into root.ln_1.tb_6141(time,`chushuiNH4-N_DOUBLE`) aligned
values(1679365910000,12.0);",
+ "insert into root.ln_1.tb_6141(time,`kaiguanliang-yunxing_BOOLEAN`)
aligned values(1675995566000,false);",
+ };
+
+ try (Connection connection = EnvFactory.getEnv().getConnection();
+ Statement statement = connection.createStatement()) {
+
+ // create aligned and non-aligned time series
+ for (String sql : sqls) {
+ statement.addBatch(sql);
+ }
+ statement.executeBatch();
+ } catch (Exception e) {
+ e.printStackTrace();
+ fail(e.getMessage());
+ }
+
+ Set<String> retSet =
+ new HashSet<>(
+ Arrays.asList(
+ "1679477545000,root.ln_1.tb_6141.gongnengma_DOUBLE,2.0,DOUBLE",
+ "1675995566000,root.ln_1.tb_6141.wenben_TEXT,52,TEXT"));
+
+ try (Connection connection = EnvFactory.getEnv().getConnection();
+ Statement statement = connection.createStatement()) {
+
+ try (ResultSet resultSet =
+ statement.executeQuery("select last gongnengma,wenben from
root.ln_1.tb_6141;")) {
+ int cnt = 0;
+ while (resultSet.next()) {
+ String ans =
+ resultSet.getString(TIMESTAMP_STR)
+ + ","
+ + resultSet.getString(TIMESEIRES_STR)
+ + ","
+ + resultSet.getString(VALUE_STR)
+ + ","
+ + resultSet.getString(DATA_TYPE_STR);
+ assertTrue(ans, retSet.contains(ans));
+ cnt++;
+ }
+ assertEquals(retSet.size(), cnt);
+ }
+
+ } catch (SQLException e) {
+ e.printStackTrace();
+ fail(e.getMessage());
+ }
+
+ retSet =
+ new HashSet<>(
+ Arrays.asList(
+ "1679477545000,root.ln_1.tb_6141.gongnengma_DOUBLE,2.0,DOUBLE",
+
"1677033625000,root.ln_1.tb_6141.mochanshuizhuangtai_BOOLEAN,true,BOOLEAN",
+ "1675995566000,root.ln_1.tb_6141.wenben_TEXT,52,TEXT"));
+
+ try (Connection connection = EnvFactory.getEnv().getConnection();
+ Statement statement = connection.createStatement()) {
+
+ try (ResultSet resultSet =
+ statement.executeQuery(
+ "select last gongnengma,mochanshuizhuangtai,wenben from
root.ln_1.tb_6141;")) {
+ int cnt = 0;
+ while (resultSet.next()) {
+ String ans =
+ resultSet.getString(TIMESTAMP_STR)
+ + ","
+ + resultSet.getString(TIMESEIRES_STR)
+ + ","
+ + resultSet.getString(VALUE_STR)
+ + ","
+ + resultSet.getString(DATA_TYPE_STR);
+ assertTrue(ans, retSet.contains(ans));
+ cnt++;
+ }
+ assertEquals(retSet.size(), cnt);
+ }
+
+ } catch (SQLException e) {
+ e.printStackTrace();
+ fail(e.getMessage());
+ }
+ }
}
diff --git
a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/utils/datastructure/AlignedTVList.java
b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/utils/datastructure/AlignedTVList.java
index dcf920afd7d..676831bd231 100644
---
a/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/utils/datastructure/AlignedTVList.java
+++
b/iotdb-core/datanode/src/main/java/org/apache/iotdb/db/utils/datastructure/AlignedTVList.java
@@ -1115,7 +1115,11 @@ public abstract class AlignedTVList extends TVList {
Column column = previousTsBlock.getColumn(columnIndex);
for (int i = 0; i < previousValidRowCount; i++) {
if (hasAnyNonNullValue[i]) {
- columnBuilder.write(column, i);
+ if (column.isNull(i)) {
+ columnBuilder.appendNull();
+ } else {
+ columnBuilder.write(column, i);
+ }
}
}
}