Skip to content

Commit

Permalink
fix(direct-cdc): improve type match for pg-cdc (#19409) (#19410)
Browse files Browse the repository at this point in the history
Co-authored-by: Kexiang Wang <[email protected]>
  • Loading branch information
github-actions[bot] and KeXiangWang authored Nov 18, 2024
1 parent 9988269 commit 2fae169
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 2 deletions.
2 changes: 1 addition & 1 deletion e2e_test/source_legacy/cdc_inline/postgres_create_drop.slt
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ control substitution on
system ok
psql -c "
DROP TABLE IF EXISTS tt1;
CREATE TABLE tt1 (v1 int primary key, v2 timestamp);
CREATE TABLE tt1 (v1 int primary key, v2 timestamptz);
INSERT INTO tt1 VALUES (1, '2023-10-23 10:00:00');"

statement ok
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,6 @@ private boolean isDataTypeCompatible(String mysqlDataType, Data.DataType.TypeNam
&& val <= Data.DataType.TypeName.INT64_VALUE;
case "bigint":
return val == Data.DataType.TypeName.INT64_VALUE;

case "float":
case "real":
return val == Data.DataType.TypeName.FLOAT_VALUE
Expand All @@ -303,6 +302,12 @@ private boolean isDataTypeCompatible(String mysqlDataType, Data.DataType.TypeNam
return val == Data.DataType.TypeName.DECIMAL_VALUE;
case "varchar":
return val == Data.DataType.TypeName.VARCHAR_VALUE;
case "date":
return val == Data.DataType.TypeName.DATE_VALUE;
case "time":
return val == Data.DataType.TypeName.TIME_VALUE;
case "datetime":
return val == Data.DataType.TypeName.TIMESTAMP_VALUE;
case "timestamp":
return val == Data.DataType.TypeName.TIMESTAMPTZ_VALUE;
default:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -680,7 +680,25 @@ private boolean isDataTypeCompatible(String pgDataType, Data.DataType.TypeName t
|| val == Data.DataType.TypeName.VARCHAR_VALUE;
case "varchar":
case "character varying":
case "uuid":
case "enum":
return val == Data.DataType.TypeName.VARCHAR_VALUE;
case "bytea":
return val == Data.DataType.TypeName.BYTEA_VALUE;
case "date":
return val == Data.DataType.TypeName.DATE_VALUE;
case "time":
return val == Data.DataType.TypeName.TIME_VALUE;
case "timestamp":
case "timestamp without time zone":
return val == Data.DataType.TypeName.TIMESTAMP_VALUE;
case "timestamptz":
case "timestamp with time zone":
return val == Data.DataType.TypeName.TIMESTAMPTZ_VALUE;
case "interval":
return val == Data.DataType.TypeName.INTERVAL_VALUE;
case "jsonb":
return val == Data.DataType.TypeName.JSONB_VALUE;
default:
return true; // true for other uncovered types
}
Expand Down

0 comments on commit 2fae169

Please sign in to comment.