Kirill Tkalenko created CALCITE-7637:
----------------------------------------
Summary: Fix DML for overloaded binary operators in Calcite engine
Key: CALCITE-7637
URL: https://issues.apache.org/jira/browse/CALCITE-7637
Project: Calcite
Issue Type: Bug
Reporter: Kirill Tkalenko
Assignee: Kirill Tkalenko
I discovered that when overloading a binary operator in the Calcite engine, it
works for SELECT statements but not for UPDATE statements.
For example, when overloading the binary operator "-" for the operation
TIMESTAMP -NIMERIC, SELECT queries work as expected, but UPDATE queries do not;
this needs to be fixed.
{code:java}
sql("create table person(id int primary key, val_ts timestamp)"); sql("insert
into person values (?, ?)", 1, Timestamp.valueOf("2024-01-01 00:00:00"));
// Check SELECT - works. assertQuery("SELECT val_ts - 1 FROM person")
.returns(Timestamp.valueOf("2023-12-31 00:00:00")) .check();
// Check UPDATE - fails. assertQuery("UPDATE person SET val_ts = val_ts - 1
WHERE id = ?") .withParams(1) .returns(1L) .check();
{code}
--
This message was sent by Atlassian Jira
(v8.20.10#820010)