From: Vladislav Shpilevoy <v.shpilevoy@tarantool.org> To: tarantool-patches@freelists.org, Nikita Pettik <korablev@tarantool.org> Cc: Georgy Kirichenko <georgy@tarantool.org> Subject: [tarantool-patches] Re: [PATCH 3/6] sql: pass true types of columns to Tarantool Date: Thu, 27 Sep 2018 23:23:57 +0300 [thread overview] Message-ID: <a9049b73-c83e-7097-9ee2-3f54691b5a8f@tarantool.org> (raw) In-Reply-To: <9a94105515bd4f9148f302b24230d0918cfccdf9.1537216078.git.korablev@tarantool.org> See 3 comments below. On 17/09/2018 23:32, Nikita Pettik wrote: > From: Georgy Kirichenko <georgy@tarantool.org> > > As a main part of introducing strict typing in SQL it is required to > prohibit typeless columns in parser's grammar. Originally, SQLite simply > assigns typeless columns to BLOB affinity. Moreover, due to historical > reasons, all columns were stored with <SCALAR> type in Tarantool core > (except for <INTEGER> when it comes to primary key). Column type should > be defined on table creation. Allowed data types are: <TEXT>, <VARCHAR>, > <CHAR>, <BLOB>, <INT[EGER]>, <REAL>, <FLOAT>, <NUMERIC>, <DECIMAL>, > <DOUBLE> <DATE> and <DATETIME>. However, still any declared data type is > converted to one of <BLOB>, <TEXT>, <REAL> or <INTEGER> affinities. > While affinity reaches space format, it is (again) converted to > Tarantool's field type. To be more precise, table of conversions: > > +----------+----------+------------+ > | SQL TYPE | AFFINITY | FIELD TYPE | > +----------+----------+------------+ > | FLOAT | REAL | NUMBER | > | REAL | REAL | NUMBER | > | DOUBLE | REAL | NUMBER | > | NUMERIC | REAL | NUMBER | > | DECIMAL | REAL | NUMBER | > | INTEGER | INTEGER | INTEGER | > | TEXT | TEXT | STRING | > | VARCHAR | TEXT | STRING | > | CHAR | TEXT | STRING | > | BLOB | BLOB | SCALAR | > | DATETIME | REAL | NUMBER | > | DATE | REAL | NUMBER | > | TIME | REAL | NUMBER | > +----------+----------+------------+ > > <VARCHAR> and <CHAR> types should be specified with length > (e.g. name VARCHAR(10)), but this length currently is not used when > types are processed. Only purpose is to support ANSI syntax. > The same for <NUMERIC> and <DECIMAL> - it is allowed to specify scale > and precision, but they don't affect the way they are stored in memory. > > Note that patch is not self-sufficient: a lot of tests still fail due to > wrong types conversions. Fix for that comes as next patch. > > Closes #3018 > Closes #3104 > Closes #2494 > diff --git a/src/box/sql/expr.c b/src/box/sql/expr.c > index b57e3811d..cde6bf996 100644 > --- a/src/box/sql/expr.c > +++ b/src/box/sql/expr.c > @@ -99,6 +99,22 @@ sqlite3ExprAffinity(Expr * pExpr) > return sqlite3ExprAffinity(pExpr->pLeft->x.pSelect->pEList-> > a[pExpr->iColumn].pExpr); > } > + if (op == TK_PLUS) { > + assert(pExpr->pRight != NULL && pExpr->pLeft != NULL); > + enum affinity_type lhs_aff = sqlite3ExprAffinity(pExpr->pLeft); > + enum affinity_type rhs_aff = sqlite3ExprAffinity(pExpr->pRight); > + return sql_affinity_result(rhs_aff, lhs_aff); > + } > + if (op == TK_COLUMN) { > + assert(pExpr->space_def != NULL); > + const char *col_name = pExpr->u.zToken; > + size_t name_len = strlen(col_name); > + uint32_t field_no; > + tuple_fieldno_by_name(pExpr->space_def->dict, col_name, name_len, > + field_name_hash(col_name, name_len), > + &field_no); 1. Why are you sure that tuple_fieldno_by_name can not return an error? 2. This code is unreachable - in the same function on line 93 TK_COLUMN is processed already. What is curious - I removed this hunk entirely and next commit's tests passed. So op == TK_PLUS check here is not needed as well, is it? I guess, it is already processed in another place. > + return pExpr->space_def->fields[field_no].affinity; > + } > return pExpr->affinity; > } > > diff --git a/test/sql/on-conflict.result b/test/sql/on-conflict.result > index 63fe48e79..290aa4162 100644 > --- a/test/sql/on-conflict.result > +++ b/test/sql/on-conflict.result > @@ -1,9 +1,17 @@ > test_run = require('test_run').new() > --- > ... > +--- > +... > +--- > +... 3. wtf ??? > engine = test_run:get_cfg('engine') > --- > ... > +--- > +... > +--- > +...
next prev parent reply other threads:[~2018-09-27 20:24 UTC|newest] Thread overview: 39+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-09-17 20:32 [tarantool-patches] [PATCH 0/6] Introduce strict typing for SQL Nikita Pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 1/6] sql: split conflict action and affinity for Expr Nikita Pettik 2018-09-19 2:16 ` [tarantool-patches] " Konstantin Osipov 2018-09-27 20:24 ` Vladislav Shpilevoy 2018-10-12 11:18 ` n.pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 2/6] sql: annotate SQL functions with return type Nikita Pettik 2018-09-27 20:23 ` [tarantool-patches] " Vladislav Shpilevoy 2018-10-12 11:18 ` n.pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 3/6] sql: pass true types of columns to Tarantool Nikita Pettik 2018-09-19 2:23 ` [tarantool-patches] " Konstantin Osipov 2018-10-12 11:19 ` n.pettik 2018-09-27 20:23 ` Vladislav Shpilevoy [this message] 2018-10-12 11:18 ` n.pettik 2018-10-17 21:45 ` Vladislav Shpilevoy 2018-10-23 23:28 ` n.pettik 2018-10-29 21:32 ` Vladislav Shpilevoy 2018-11-02 2:36 ` n.pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 4/6] sql: enforce implicit type conversions Nikita Pettik 2018-09-19 2:25 ` [tarantool-patches] " Konstantin Osipov 2018-09-27 20:24 ` Vladislav Shpilevoy 2018-10-12 11:19 ` n.pettik 2018-10-17 21:45 ` Vladislav Shpilevoy 2018-10-23 23:28 ` n.pettik 2018-10-29 21:32 ` Vladislav Shpilevoy 2018-11-02 2:36 ` n.pettik 2018-11-02 11:15 ` Vladislav Shpilevoy 2018-11-02 13:26 ` n.pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 5/6] sql: return result-set type via IProto Nikita Pettik 2018-09-19 2:26 ` [tarantool-patches] " Konstantin Osipov 2018-09-27 20:24 ` Vladislav Shpilevoy 2018-10-12 11:19 ` n.pettik 2018-10-17 21:45 ` Vladislav Shpilevoy 2018-10-23 23:28 ` n.pettik 2018-09-17 20:32 ` [tarantool-patches] [PATCH 6/6] sql: discard numeric conversion by unary plus Nikita Pettik 2018-09-27 20:24 ` [tarantool-patches] " Vladislav Shpilevoy 2018-10-12 11:19 ` n.pettik 2018-09-27 20:24 ` [tarantool-patches] Re: [PATCH 0/6] Introduce strict typing for SQL Vladislav Shpilevoy 2018-10-12 11:18 ` n.pettik 2018-11-03 2:41 ` Kirill Yukhin
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=a9049b73-c83e-7097-9ee2-3f54691b5a8f@tarantool.org \ --to=v.shpilevoy@tarantool.org \ --cc=georgy@tarantool.org \ --cc=korablev@tarantool.org \ --cc=tarantool-patches@freelists.org \ --subject='[tarantool-patches] Re: [PATCH 3/6] sql: pass true types of columns to Tarantool' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox