flinkStreamSQL icon indicating copy to clipboard operation
flinkStreamSQL copied to clipboard

1.10版本中发现连续Join时抛出数组越界异常

Open bcwoauthtest opened this issue 5 years ago • 3 comments

我将flinkStreamSql从1.8.1升级到1.10,原来可以运行的Join语句出错了。 tableA是源表, tableB 是维表,执行下面的语句 CREATE VIEW v_a_join_b AS SELECT A.col_a1,A.col_a2,A.col_a3,B1.col_b as col_b1,B2.col_b as col_b2 FROM tableA AS A LEFT JOIN tableB AS B1 ON A.col_a1 = B1.col_b LEFT JOIN tableB AS B2 ON A.col_a2 = B2.col_b; 在com.dtstack.flink.sql.side.ParserJoinField类的 private static List<FieldInfo> getAllField(JoinScope scope) 方法中 会出现124行,String[] fieldNames = field.getFieldNames(); 只有两个字段f1,f2,其中f1是true,f2是Row其实包含了很多字段。 但是在126行,field.getTotalFields()会是实际包含的字段数,这样在127行, String fieldName = fieldNames[i]; 就会抛出数组越界的异常。 这个问题只在 多次Join需要进行表转流,流转表的时候才会遇到。 UI5M81IRAH)Y3YB NRF6726

bcwoauthtest avatar Apr 19 '20 07:04 bcwoauthtest

@bcwoauthtest 我们复现下,尽快修复。

todd5167 avatar Apr 20 '20 01:04 todd5167

好的,有什么需要我配合的吗?

bcwoauthtest avatar Apr 20 '20 02:04 bcwoauthtest

@todd5167 好的,有什么需要我配合的吗?

bcwoauthtest avatar Apr 21 '20 14:04 bcwoauthtest