Hi,

There is a ticket to track it: https://issues.apache.org/jira/browse/IGNITE-6111.


On 17.10.2017 11:16, Иван Федотов wrote:
Hello, Igniters!


Currently, if one try to execute `INSERT INTO t1 VALUES(...);` it will be
“IgniteSQLException: Failed to parse query: INSERT INTO Person VALUES(?,?)

…

Caused by: class
org.apache.ignite.internal.processors.query.IgniteSQLException: Failed to
parse query: INSERT INTO Person VALUES(?,?)

…

Caused by: org.h2.jdbc.JdbcSQLException: Неверное количество столбцов”

It looks like a bug, because:


          1.H2 supports format “Insert into t1 values()” [1]

          2.SQL-92 tells us it is a correct query. Paragraph 13.8 - insert
statement, syntax rules[2].


So, I want to create ticket to fix it, what do you think?


Reproducer:


public class IgniteSqlAllColumnsInsertTest extends GridCommonAbstractTest {

    public void testSqlInsert() throws Exception {

        try (Ignite ignite = startGrid(0)) {

            CacheConfiguration<Integer, Integer> cacheCfg = new
CacheConfiguration<Integer, Integer>("CachePerson").setSqlSchema("PUBLIC");


            IgniteCache<Integer, Integer> cache =
ignite.getOrCreateCache(cacheCfg);


            cache.query(new SqlFieldsQuery("CREATE TABLE Person (Name
varchar, Age int, primary key (Name))"));


            // Good query

            QueryCursor<List<?>> cursor = cache.query(

                new SqlFieldsQuery("INSERT INTO Person (Name, Age) VALUES
(?,?)")

                    .setArgs("Alice", 23)

            );


            assertEquals(1L, cursor.getAll().get(0).<Long>get(0));


            // Bad query

            cursor = cache.query(

                new SqlFieldsQuery("INSERT INTO Person VALUES(?,?)")

                    .setArgs("Bob", 25)

            );


            assertEquals(1L, cursor.getAll().get(0).<Long>get(0));

        }

    }

}




[1] http://www.h2database.com/html/history.html


[2]http://www.contrib.andrew.cmu.edu/~shadow/sql/sql1992.txt



--
Taras Ledkov
Mail-To: tled...@gridgain.com

Reply via email to