From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from [87.239.111.99] (localhost [127.0.0.1]) by dev.tarantool.org (Postfix) with ESMTP id 9D35A6EC55; Mon, 12 Jul 2021 11:50:56 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 dev.tarantool.org 9D35A6EC55 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=tarantool.org; s=dev; t=1626079856; bh=dbM4BIctqYmCOkePtU5qsZ73ZHOyFB/X8nkeAW4MybE=; h=Date:To:Cc:References:In-Reply-To:Subject:List-Id: List-Unsubscribe:List-Archive:List-Post:List-Help:List-Subscribe: From:Reply-To:From; b=ndi3A6DQeRfN/vL5av1lfM6E2lNOruFeEWQq331n+1eHZDn0O/LkKU+rhARFHZTMS rjNea+iShABT6ee4hcrDKHGchBOE/Yccj98g3IiW4NQsUR+FN439SWFLa+cCb8NeHE CXlPmjN7C2cudCFmDJ979dJVOx/G7jFVllDn04y4= Received: from smtpng1.i.mail.ru (smtpng1.i.mail.ru [94.100.181.251]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dev.tarantool.org (Postfix) with ESMTPS id 03E366EC55 for ; Mon, 12 Jul 2021 11:50:55 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 dev.tarantool.org 03E366EC55 Received: by smtpng1.m.smailru.net with esmtpa (envelope-from ) id 1m2reP-0000tJ-SA; Mon, 12 Jul 2021 11:50:54 +0300 Date: Mon, 12 Jul 2021 11:50:52 +0300 To: Vladislav Shpilevoy Cc: tarantool-patches@dev.tarantool.org Message-ID: <20210712085052.GA127980@tarantool.org> References: <23623e4a-eb22-03b0-7e5b-841f30e725a4@tarantool.org> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <23623e4a-eb22-03b0-7e5b-841f30e725a4@tarantool.org> X-4EC0790: 10 X-7564579A: 646B95376F6C166E X-77F55803: 4F1203BC0FB41BD954DFF1DC42D673FB1FB1A3F86EB146194530BD4386868AAF182A05F538085040A6B7286488572E5B114BA6EB54C2BEF365094C6EE8362034CDA22C17825E95E3 X-7FA49CB5: FF5795518A3D127A4AD6D5ED66289B5278DA827A17800CE7195F30236A8D43B4EA1F7E6F0F101C67BD4B6F7A4D31EC0BCC500DACC3FED6E28638F802B75D45FF8AA50765F7900637486F32EF78EC606F8638F802B75D45FF36EB9D2243A4F8B5A6FCA7DBDB1FC311F39EFFDF887939037866D6147AF826D8EB2C282C59EAAD138216E8EFEA67FA1F117882F4460429724CE54428C33FAD305F5C1EE8F4F765FCAA867293B0326636D2E47CDBA5A96583BD4B6F7A4D31EC0BC014FD901B82EE079FA2833FD35BB23D27C277FBC8AE2E8BAA867293B0326636D2E47CDBA5A96583BA9C0B312567BB231DD303D21008E29813377AFFFEAFD269A417C69337E82CC2E827F84554CEF50127C277FBC8AE2E8BA83251EDC214901ED5E8D9A59859A8B62CFFCC7B69C47339089D37D7C0E48F6C5571747095F342E88FB05168BE4CE3AF X-C1DE0DAB: 0D63561A33F958A5F9C17FC5D0E937FC19B5587BAAB6E9241D636F41B06FE8F5D59269BC5F550898D99A6476B3ADF6B47008B74DF8BB9EF7333BD3B22AA88B938A852937E12ACA753753CEE10E4ED4A7410CA545F18667F91A7EA1CDA0B5A7A0 X-C8649E89: 4E36BF7865823D7055A7F0CF078B5EC49A30900B95165D348D68DCC07DD06FF52A192B7D4095DC02FC7E499238ED15C84FC4B0C675D7AE99926D181A9324B60D1D7E09C32AA3244CD5B15DE906480D08CEABF8B6A653CB97A90944CA99CF22E3729B2BEF169E0186 X-D57D3AED: 3ZO7eAau8CL7WIMRKs4sN3D3tLDjz0dLbV79QFUyzQ2Ujvy7cMT6pYYqY16iZVKkSc3dCLJ7zSJH7+u4VD18S7Vl4ZUrpaVfd2+vE6kuoey4m4VkSEu530nj6fImhcD4MUrOEAnl0W826KZ9Q+tr5ycPtXkTV4k65bRjmOUUP8cvGozZ33TWg5HZplvhhXbhDGzqmQDTd6OAevLeAnq3Ra9uf7zvY2zzsIhlcp/Y7m53TZgf2aB4JOg4gkr2bioj/3sbGI30Xhc0PJcfP085Og== X-Mailru-Sender: 689FA8AB762F7393C37E3C1AEC41BA5D5FA4CBB9692262C21B13B6DD75878F6883D72C36FC87018B9F80AB2734326CD2FB559BB5D741EB96352A0ABBE4FDA4210A04DAD6CC59E33667EA787935ED9F1B X-Mras: Ok Subject: Re: [Tarantool-patches] [PATCH v2 1/4] sql: truncate values in type mismatch error X-BeenThere: tarantool-patches@dev.tarantool.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: Tarantool development patches List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , From: Mergen Imeev via Tarantool-patches Reply-To: Mergen Imeev Errors-To: tarantool-patches-bounces@dev.tarantool.org Sender: "Tarantool-patches" Hi! Thank you for the review! My answers and new patches below. I included first three patches here since there were some conflicts due to changes in this patch. The last patch will be included in its own letter. In all these patches were no changes in tests, the only changes were in mem_str() function. On Thu, Jul 08, 2021 at 12:09:12AM +0200, Vladislav Shpilevoy wrote: > Hi! Thanks for the patch! > > See 2 comments below. > > > diff --git a/src/box/sql/mem.c b/src/box/sql/mem.c > > index 6f3bf52e5..630f1a135 100644 > > --- a/src/box/sql/mem.c > > +++ b/src/box/sql/mem.c > > @@ -71,26 +72,35 @@ mem_is_field_compatible(const struct Mem *mem, enum field_type type) > > const char * > > mem_str(const struct Mem *mem) > > { > > - char buf[BUF_SIZE]; > > + char buf[STR_VALUE_MAX_LEN + 1]; > > switch (mem->type) { > > case MEM_TYPE_NULL: > > return "NULL"; > > case MEM_TYPE_STR: > > - if ((mem->flags & MEM_Term) != 0) > > - return mem->z; > > + if (mem->n > STR_VALUE_MAX_LEN) { > > + memcpy(buf, mem->z, STR_VALUE_MAX_LEN); > > + buf[STR_VALUE_MAX_LEN] = '\0'; > > + return tt_sprintf("%s...", buf); > > 1. Can be done simpler using %.*s in tt_sprintf() with the length > limited by STR_VALUE_MAX_LEN. > Thanks! Fixed everywhere. > > + } > > return tt_cstr(mem->z, mem->n); > > case MEM_TYPE_INT: > > return tt_sprintf("%lld", mem->u.i); > > case MEM_TYPE_UINT: > > return tt_sprintf("%llu", mem->u.u); > > case MEM_TYPE_DOUBLE: > > - sql_snprintf(BUF_SIZE, &buf[0], "%!.15g", mem->u.r); > > + sql_snprintf(STR_VALUE_MAX_LEN + 1, buf, "%!.15g", mem->u.r); > > return tt_sprintf("%s", buf); > > case MEM_TYPE_BIN: > > return "varbinary"; > > case MEM_TYPE_MAP: > > - case MEM_TYPE_ARRAY: > > - return mp_str(mem->z); > > + case MEM_TYPE_ARRAY: { > > + const char *str = mp_str(mem->z); > > + if (strlen(str) <= STR_VALUE_MAX_LEN) > > + return str; > > + memcpy(buf, str, STR_VALUE_MAX_LEN); > > + buf[STR_VALUE_MAX_LEN] = '\0'; > > + return tt_sprintf("%s...", buf); > > 2. Ditto. Fixed. New patches: First patch: commit f2bcdef6ed88f845f36ed600fcbad32630e95718 Author: Mergen Imeev Date: Sun Jul 4 20:27:38 2021 +0300 sql: truncate values in type mismatch error STRING, MAP, and ARRAY values that are too long can make the type mismatch error description less descriptive than necessary. This patch truncates values that are too long and adds "..." to indicate that the value has been truncated. Part of #6176 diff --git a/src/box/sql/mem.c b/src/box/sql/mem.c index 2595e2fd4..05f053c55 100644 --- a/src/box/sql/mem.c +++ b/src/box/sql/mem.c @@ -57,6 +57,7 @@ sqlVdbeMemGrow(struct Mem *pMem, int n, int preserve); enum { BUF_SIZE = 32, + STR_VALUE_MAX_LEN = 128, }; bool @@ -72,26 +73,31 @@ mem_is_field_compatible(const struct Mem *mem, enum field_type type) const char * mem_str(const struct Mem *mem) { - char buf[BUF_SIZE]; + char buf[STR_VALUE_MAX_LEN]; switch (mem->type) { case MEM_TYPE_NULL: return "NULL"; case MEM_TYPE_STR: - if ((mem->flags & MEM_Term) != 0) - return mem->z; + if (mem->n > STR_VALUE_MAX_LEN) + return tt_sprintf("%.*s...", STR_VALUE_MAX_LEN, mem->z); return tt_cstr(mem->z, mem->n); case MEM_TYPE_INT: return tt_sprintf("%lld", mem->u.i); case MEM_TYPE_UINT: return tt_sprintf("%llu", mem->u.u); case MEM_TYPE_DOUBLE: - sql_snprintf(BUF_SIZE, &buf[0], "%!.15g", mem->u.r); + sql_snprintf(STR_VALUE_MAX_LEN, buf, "%!.15g", mem->u.r); return tt_sprintf("%s", buf); case MEM_TYPE_BIN: return "varbinary"; case MEM_TYPE_MAP: - case MEM_TYPE_ARRAY: - return mp_str(mem->z); + case MEM_TYPE_ARRAY: { + const char *str = mp_str(mem->z); + if (strlen(str) <= STR_VALUE_MAX_LEN) + return str; + memcpy(buf, str, STR_VALUE_MAX_LEN); + return tt_sprintf("%.*s...", STR_VALUE_MAX_LEN, buf); + } case MEM_TYPE_UUID: return tt_uuid_str(&mem->u.uuid); case MEM_TYPE_BOOL: diff --git a/src/box/sql/mem.h b/src/box/sql/mem.h index b3cd5c545..0bbc63e68 100644 --- a/src/box/sql/mem.h +++ b/src/box/sql/mem.h @@ -264,7 +264,8 @@ mem_is_field_compatible(const struct Mem *mem, enum field_type type); /** * Return a string that represent content of MEM. String is either allocated - * using static_alloc() of just a static variable. + * using static_alloc() of just a static variable. This function should only be + * used for debugging or displaying MEM values in errors. */ const char * mem_str(const struct Mem *mem); diff --git a/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua b/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua index da8c2dcd6..28cf50184 100755 --- a/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua +++ b/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua @@ -34,12 +34,7 @@ test:do_catchsql_test( "SELECT CAST('" .. long_str .. "1234'" .. " AS INTEGER);", { 1, "Type mismatch: can not convert 000000000000000000000000000000000" .. "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000000000000000000000000000000000000000000" .. - "000000000000000000000000000000000000000000000" + "0000000000000000000000000000... to integer" }) test:finish_test() diff --git a/test/sql-tap/sql-errors.test.lua b/test/sql-tap/sql-errors.test.lua index 469193a2b..96ee683eb 100755 --- a/test/sql-tap/sql-errors.test.lua +++ b/test/sql-tap/sql-errors.test.lua @@ -1,6 +1,6 @@ #!/usr/bin/env tarantool local test = require("sqltester") -test:plan(72) +test:plan(76) test:execsql([[ CREATE TABLE t0 (i INT PRIMARY KEY, a INT); @@ -780,4 +780,49 @@ test:do_catchsql_test( -- }) +-- +-- gh-6176: Make sure that type mismatch error description with too long STRING, +-- MAP or ARRAY is printed correctly. +-- +local str1 = string.rep('a', 200) +local str2 = string.rep('ы', 200) + +test:do_catchsql_test( + "sql-errors-3.1", + "SELECT CAST('"..str1.."'AS UNSIGNED);", { + 1, "Type mismatch: can not convert aaaaaaaaaaaaaaaaaaaaaaaaaa".. + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa".. + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... to unsigned" + }) + +test:do_catchsql_test( + "sql-errors-3.2", + "SELECT CAST('"..str2.."'AS UNSIGNED);", { + 1, "Type mismatch: can not convert ыыыыыыыыыыыыыыыыыыыыыыыыыы".. + "ыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыы... to unsigned" + }) + +local format = {{'I', 'integer'}, {'A', 'array'}, {'M', 'map'}} +local s = box.schema.space.create('TEST', {format=format}) +s:create_index('I') +s:insert({1, {str1}, {a = 1, b = str1}}) + +test:do_catchsql_test( + "sql-errors-3.3", + "SELECT CAST(a AS UNSIGNED) from test;", { + 1, 'Type mismatch: can not convert ["aaaaaaaaaaaaaaaaaaaaaaaa'.. + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.. + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... to unsigned' + }) + +test:do_catchsql_test( + "sql-errors-3.4", + "SELECT CAST(m AS UNSIGNED) from test;", { + 1, 'Type mismatch: can not convert {"a": 1, "b": "aaaaaaaaaaa'.. + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'.. + 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... to unsigned' + }) + +test:execsql('DROP TABLE test;') + test:finish_test() diff --git a/test/sql/types.result b/test/sql/types.result index 687ca3b15..a46967158 100644 --- a/test/sql/types.result +++ b/test/sql/types.result @@ -1651,11 +1651,7 @@ box.execute('INSERT INTO t1(a) SELECT a FROM t2;') - null - 'Type mismatch: can not convert [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, - 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, - 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, - 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, - 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, - 112, 113, 114, 115, 116, 117, 11' + ... to scalar' ... s:drop() --- Second patch: commit ab3ec1e174a2268899a01e4ee7dfaff47c610456 Author: Mergen Imeev Date: Mon Jun 21 21:19:51 2021 +0300 sql: properly show values in type mismatch error Currently, some values are displayed improperly in the type mismatch error description. For VARBINARY, the word "varbinary" is printed instead of the value. STRING values are printed without quotes, which can be confusing in some cases, such as when it consists of spaces. This patch introduces the following changes: 1) VARBINARY value will be printed as x''. 2) STRING value will be printed in single quotes. 3) UUID value will be printed in single quotes. UUID value does not need to be enclosed in single quotes, since there are no literals for UUIDs, but it looks more convenient. Part of #6176 diff --git a/src/box/sql/mem.c b/src/box/sql/mem.c index 05f053c55..3bbff9897 100644 --- a/src/box/sql/mem.c +++ b/src/box/sql/mem.c @@ -79,8 +79,8 @@ mem_str(const struct Mem *mem) return "NULL"; case MEM_TYPE_STR: if (mem->n > STR_VALUE_MAX_LEN) - return tt_sprintf("%.*s...", STR_VALUE_MAX_LEN, mem->z); - return tt_cstr(mem->z, mem->n); + return tt_sprintf("'%.*s...", STR_VALUE_MAX_LEN, mem->z); + return tt_sprintf("'%.*s'", mem->n, mem->z); case MEM_TYPE_INT: return tt_sprintf("%lld", mem->u.i); case MEM_TYPE_UINT: @@ -88,8 +88,18 @@ mem_str(const struct Mem *mem) case MEM_TYPE_DOUBLE: sql_snprintf(STR_VALUE_MAX_LEN, buf, "%!.15g", mem->u.r); return tt_sprintf("%s", buf); - case MEM_TYPE_BIN: - return "varbinary"; + case MEM_TYPE_BIN: { + int len = MIN(mem->n, STR_VALUE_MAX_LEN / 2); + for (int i = 0; i < len; ++i) { + int n = (mem->z[i] & 0xF0) >> 4; + buf[2 * i] = n < 10 ? ('0' + n) : ('A' + n - 10); + n = (mem->z[i] & 0x0F); + buf[2 * i + 1] = n < 10 ? ('0' + n) : ('A' + n - 10); + } + if (mem->n > len) + return tt_sprintf("x'%.*s...", len * 2, buf); + return tt_sprintf("x'%.*s'", len * 2, buf); + } case MEM_TYPE_MAP: case MEM_TYPE_ARRAY: { const char *str = mp_str(mem->z); @@ -99,7 +109,8 @@ mem_str(const struct Mem *mem) return tt_sprintf("%.*s...", STR_VALUE_MAX_LEN, buf); } case MEM_TYPE_UUID: - return tt_uuid_str(&mem->u.uuid); + tt_uuid_to_string(&mem->u.uuid, buf); + return tt_sprintf("'%s'", buf); case MEM_TYPE_BOOL: return mem->u.b ? "TRUE" : "FALSE"; default: diff --git a/test/sql-tap/autoinc.test.lua b/test/sql-tap/autoinc.test.lua index aa457b502..83d983fe1 100755 --- a/test/sql-tap/autoinc.test.lua +++ b/test/sql-tap/autoinc.test.lua @@ -616,7 +616,7 @@ test:do_catchsql_test( INSERT INTO t2 VALUES('asd'); ]], { -- - 1, "Type mismatch: can not convert asd to integer" + 1, "Type mismatch: can not convert 'asd' to integer" -- }) @@ -809,7 +809,7 @@ test:do_catchsql_test( INSERT INTO t1 SELECT s2, s2 FROM t1; ]], { -- - 1, "Type mismatch: can not convert a to integer" + 1, "Type mismatch: can not convert 'a' to integer" -- }) diff --git a/test/sql-tap/cast.test.lua b/test/sql-tap/cast.test.lua index 7de4b79df..e2a227127 100755 --- a/test/sql-tap/cast.test.lua +++ b/test/sql-tap/cast.test.lua @@ -70,7 +70,7 @@ test:do_catchsql_test( SELECT CAST(x'616263' AS NUMBER) ]], { -- - 1, 'Type mismatch: can not convert varbinary to number' + 1, "Type mismatch: can not convert x'616263' to number" -- }) @@ -100,7 +100,7 @@ test:do_catchsql_test( SELECT CAST(x'616263' AS integer) ]], { -- - 1, 'Type mismatch: can not convert varbinary to integer' + 1, "Type mismatch: can not convert x'616263' to integer" -- }) @@ -450,7 +450,7 @@ test:do_catchsql_test( SELECT CAST('123abc' AS NUMBER) ]], { -- - 1, 'Type mismatch: can not convert 123abc to number' + 1, "Type mismatch: can not convert '123abc' to number" -- }) @@ -470,7 +470,7 @@ test:do_catchsql_test( SELECT CAST('123abc' AS integer) ]], { -- - 1, 'Type mismatch: can not convert 123abc to integer' + 1, "Type mismatch: can not convert '123abc' to integer" -- }) @@ -480,7 +480,7 @@ test:do_catchsql_test( SELECT CAST('123.5abc' AS NUMBER) ]], { -- - 1, 'Type mismatch: can not convert 123.5abc to number' + 1, "Type mismatch: can not convert '123.5abc' to number" -- }) @@ -490,7 +490,7 @@ test:do_catchsql_test( SELECT CAST('123.5abc' AS integer) ]], { -- - 1, 'Type mismatch: can not convert 123.5abc to integer' + 1, "Type mismatch: can not convert '123.5abc' to integer" -- }) @@ -561,7 +561,7 @@ test:do_catchsql_test( SELECT CAST('abc' AS NUMBER) ]], { -- - 1, 'Type mismatch: can not convert abc to number' + 1, "Type mismatch: can not convert 'abc' to number" -- }) @@ -835,7 +835,7 @@ test:do_test( ]] end, { -- - 1, 'Type mismatch: can not convert abc to integer' + 1, "Type mismatch: can not convert 'abc' to integer" -- }) @@ -847,7 +847,7 @@ test:do_test( ]] end, { -- - 1, 'Type mismatch: can not convert abc to integer' + 1, "Type mismatch: can not convert 'abc' to integer" -- }) @@ -859,7 +859,7 @@ test:do_test( ]] end, { -- - 1, 'Type mismatch: can not convert abc to number' + 1, "Type mismatch: can not convert 'abc' to number" -- }) diff --git a/test/sql-tap/func.test.lua b/test/sql-tap/func.test.lua index 5e259f7ef..ae6bc9ddd 100755 --- a/test/sql-tap/func.test.lua +++ b/test/sql-tap/func.test.lua @@ -2931,7 +2931,7 @@ test:do_catchsql_test( SELECT ROUND(X'FF') ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -2941,7 +2941,7 @@ test:do_catchsql_test( SELECT RANDOMBLOB(X'FF') ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -2951,7 +2951,7 @@ test:do_catchsql_test( SELECT SOUNDEX(X'FF') ]], { -- - 1, "Type mismatch: can not convert varbinary to text" + 1, "Type mismatch: can not convert x'FF' to text" -- }) @@ -2961,7 +2961,7 @@ test:do_catchsql_test( SELECT SUM(X'FF') ]], { -- - 1, "Type mismatch: can not convert varbinary to number" + 1, "Type mismatch: can not convert x'FF' to number" -- }) diff --git a/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua b/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua index 28cf50184..b595f99b0 100755 --- a/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua +++ b/test/sql-tap/gh-4766-wrong-cast-from-blob-to-int.test.lua @@ -32,9 +32,9 @@ test:do_execsql_test( test:do_catchsql_test( "gh-4766-3", "SELECT CAST('" .. long_str .. "1234'" .. " AS INTEGER);", { - 1, "Type mismatch: can not convert 000000000000000000000000000000000" .. + 1, "Type mismatch: can not convert '00000000000000000000000000000000" .. "0000000000000000000000000000000000000000000000000000000000000000000" .. - "0000000000000000000000000000... to integer" + "00000000000000000000000000000... to integer" }) test:finish_test() diff --git a/test/sql-tap/gh-5913-segfault-on-select-uuid.test.lua b/test/sql-tap/gh-5913-segfault-on-select-uuid.test.lua index 7dcebe5d3..59a76000a 100755 --- a/test/sql-tap/gh-5913-segfault-on-select-uuid.test.lua +++ b/test/sql-tap/gh-5913-segfault-on-select-uuid.test.lua @@ -40,7 +40,7 @@ test:do_catchsql_test( [[ INSERT INTO t1 SELECT i, NULL, d FROM t; ]], { - 1, "Type mismatch: can not convert varbinary to decimal" + 1, "Type mismatch: can not convert x'C70501030111111C' to decimal" }) -- @@ -77,7 +77,7 @@ test:do_catchsql_test( [[ UPDATE td SET d = d; ]], { - 1, "Type mismatch: can not convert varbinary to decimal" + 1, "Type mismatch: can not convert x'C70501030111111C' to decimal" }) test:finish_test() diff --git a/test/sql-tap/index1.test.lua b/test/sql-tap/index1.test.lua index a4d33152b..e03e284aa 100755 --- a/test/sql-tap/index1.test.lua +++ b/test/sql-tap/index1.test.lua @@ -778,7 +778,7 @@ test:do_catchsql_test( SELECT c FROM t6 WHERE a>123; ]], { -- - 1, "Type mismatch: can not convert to numeric" + 1, "Type mismatch: can not convert '' to numeric" -- }) @@ -788,7 +788,7 @@ test:do_catchsql_test( SELECT c FROM t6 WHERE a>=123; ]], { -- - 1, "Type mismatch: can not convert to numeric" + 1, "Type mismatch: can not convert '' to numeric" -- }) diff --git a/test/sql-tap/select1.test.lua b/test/sql-tap/select1.test.lua index 36206ca2a..1a7a4ee82 100755 --- a/test/sql-tap/select1.test.lua +++ b/test/sql-tap/select1.test.lua @@ -320,7 +320,7 @@ test:do_catchsql_test( SELECT count(*),count(a),count(b) FROM t4 WHERE b=5 ]], { -- - 1, "Type mismatch: can not convert This is a string that is too big to fit inside a NBFS buffer to numeric" + 1, "Type mismatch: can not convert 'This is a string that is too big to fit inside a NBFS buffer' to numeric" -- }) @@ -515,7 +515,7 @@ test:do_catchsql_test( SELECT sum(a) FROM t3 ]], { -- - 1, "Type mismatch: can not convert abc to number" + 1, "Type mismatch: can not convert 'abc' to number" -- }) diff --git a/test/sql-tap/select5.test.lua b/test/sql-tap/select5.test.lua index 5882102c9..bb9951025 100755 --- a/test/sql-tap/select5.test.lua +++ b/test/sql-tap/select5.test.lua @@ -558,7 +558,7 @@ test:do_catchsql_test( SELECT 1 FROM jj HAVING avg(s2) = 1 AND avg(s2) = 0; ]], { -- - 1, "Type mismatch: can not convert A to number" + 1, "Type mismatch: can not convert 'A' to number" -- }) diff --git a/test/sql-tap/sql-errors.test.lua b/test/sql-tap/sql-errors.test.lua index 96ee683eb..52276c27b 100755 --- a/test/sql-tap/sql-errors.test.lua +++ b/test/sql-tap/sql-errors.test.lua @@ -1,6 +1,6 @@ #!/usr/bin/env tarantool local test = require("sqltester") -test:plan(76) +test:plan(80) test:execsql([[ CREATE TABLE t0 (i INT PRIMARY KEY, a INT); @@ -687,7 +687,7 @@ test:do_catchsql_test( -- }) --- gh-4356: Make sure that 'varbinary' is printed instead of the +-- gh-4356: Make sure that varbinary is printed in hex instead of the -- binary data itself (since binary data can contain unprintable symbols). -- test:do_catchsql_test( @@ -696,7 +696,7 @@ test:do_catchsql_test( SELECT X'ff' + 1; ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -706,7 +706,7 @@ test:do_catchsql_test( SELECT X'ff' - 1; ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -716,7 +716,7 @@ test:do_catchsql_test( SELECT X'ff' * 1; ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -726,7 +726,7 @@ test:do_catchsql_test( SELECT X'ff' / 1; ]], { -- - 1, "Type mismatch: can not convert varbinary to numeric" + 1, "Type mismatch: can not convert x'FF' to numeric" -- }) @@ -736,7 +736,7 @@ test:do_catchsql_test( SELECT X'ff' AND true; ]], { -- - 1, "Type mismatch: can not convert varbinary to boolean" + 1, "Type mismatch: can not convert x'FF' to boolean" -- }) @@ -746,7 +746,7 @@ test:do_catchsql_test( SELECT X'ff' OR false; ]], { -- - 1, "Type mismatch: can not convert varbinary to boolean" + 1, "Type mismatch: can not convert x'FF' to boolean" -- }) @@ -756,7 +756,7 @@ test:do_catchsql_test( SELECT false OR X'ff'; ]], { -- - 1, "Type mismatch: can not convert varbinary to boolean" + 1, "Type mismatch: can not convert x'FF' to boolean" -- }) @@ -790,16 +790,16 @@ local str2 = string.rep('ы', 200) test:do_catchsql_test( "sql-errors-3.1", "SELECT CAST('"..str1.."'AS UNSIGNED);", { - 1, "Type mismatch: can not convert aaaaaaaaaaaaaaaaaaaaaaaaaa".. + 1, "Type mismatch: can not convert 'aaaaaaaaaaaaaaaaaaaaaaaaa".. "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa".. - "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... to unsigned" + "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... to unsigned" }) test:do_catchsql_test( "sql-errors-3.2", "SELECT CAST('"..str2.."'AS UNSIGNED);", { - 1, "Type mismatch: can not convert ыыыыыыыыыыыыыыыыыыыыыыыыыы".. - "ыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыы... to unsigned" + 1, "Type mismatch: can not convert 'ыыыыыыыыыыыыыыыыыыыыыыыыы".. + "ыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыыы... to unsigned" }) local format = {{'I', 'integer'}, {'A', 'array'}, {'M', 'map'}} @@ -825,4 +825,43 @@ test:do_catchsql_test( test:execsql('DROP TABLE test;') +-- +-- gh-6176: Make sure that STRING, VARBINARY and UUID values properly printed +-- in type mismatch error description. +-- +test:do_catchsql_test( + "sql-errors-3.5", + [[ + SELECT CAST(x'F1' AS UNSIGNED); + ]], { + 1, "Type mismatch: can not convert x'F1' to unsigned" + }) + +test:do_catchsql_test( + "sql-errors-3.6", + [[ + SELECT CAST('F1' AS UNSIGNED); + ]], { + 1, "Type mismatch: can not convert 'F1' to unsigned" + }) + +test:do_catchsql_test( + "sql-errors-3.7", + [[ + SELECT CAST(CAST('11111111-1111-1111-1111-111111111111' AS UUID) AS UNSIGNED); + ]], { + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to unsigned" + }) + +local bin = '' +for i = 1,99 do bin = bin .. string.format("%02x", i) end + +test:do_catchsql_test( + "sql-errors-3.8", + "SELECT CAST(x'"..bin.."'AS UNSIGNED);", { + 1, "Type mismatch: can not convert x'0102030405060708090A0B0C".. + "0D0E0F101112131415161718191A1B1C1D1E1F202122232425262728292A".. + "2B2C2D2E2F303132333435363738393A3B3C3D3E3F40... to unsigned" + }) + test:finish_test() diff --git a/test/sql-tap/tkt-80e031a00f.test.lua b/test/sql-tap/tkt-80e031a00f.test.lua index 82769587b..b5bdf038f 100755 --- a/test/sql-tap/tkt-80e031a00f.test.lua +++ b/test/sql-tap/tkt-80e031a00f.test.lua @@ -346,7 +346,7 @@ test:do_catchsql_test( SELECT 'hello' IN t1 ]], { -- - 1, 'Type mismatch: can not convert hello to integer' + 1, "Type mismatch: can not convert 'hello' to integer" -- }) @@ -356,7 +356,7 @@ test:do_catchsql_test( SELECT 'hello' NOT IN t1 ]], { -- - 1, 'Type mismatch: can not convert hello to integer' + 1, "Type mismatch: can not convert 'hello' to integer" -- }) @@ -386,7 +386,7 @@ test:do_catchsql_test( SELECT x'303132' IN t1 ]], { -- - 1, 'Type mismatch: can not convert varbinary to integer' + 1, "Type mismatch: can not convert x'303132' to integer" -- }) @@ -396,7 +396,7 @@ test:do_catchsql_test( SELECT x'303132' NOT IN t1 ]], { -- - 1, 'Type mismatch: can not convert varbinary to integer' + 1, "Type mismatch: can not convert x'303132' to integer" -- }) diff --git a/test/sql-tap/tkt-9a8b09f8e6.test.lua b/test/sql-tap/tkt-9a8b09f8e6.test.lua index 67d6a1ccd..53dfafebf 100755 --- a/test/sql-tap/tkt-9a8b09f8e6.test.lua +++ b/test/sql-tap/tkt-9a8b09f8e6.test.lua @@ -245,7 +245,7 @@ test:do_catchsql_test( SELECT x FROM t3 WHERE x IN ('1'); ]], { -- <4.3> - 1, "Type mismatch: can not convert 1 to number" + 1, "Type mismatch: can not convert '1' to number" -- }) @@ -255,7 +255,7 @@ test:do_catchsql_test( SELECT x FROM t3 WHERE x IN ('1.0'); ]], { -- <4.4> - 1, "Type mismatch: can not convert 1.0 to number" + 1, "Type mismatch: can not convert '1.0' to number" -- }) @@ -285,7 +285,7 @@ test:do_catchsql_test( SELECT x FROM t3 WHERE '1' IN (x); ]], { -- <4.7> - 1, "Type mismatch: can not convert 1 to number" + 1, "Type mismatch: can not convert '1' to number" -- }) @@ -295,7 +295,7 @@ test:do_catchsql_test( SELECT x FROM t3 WHERE '1.0' IN (x); ]], { -- <4.8> - 1, "Type mismatch: can not convert 1.0 to number" + 1, "Type mismatch: can not convert '1.0' to number" -- }) @@ -325,7 +325,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE x IN ('1'); ]], { -- <5.3> - 1, "Type mismatch: can not convert 1 to number" + 1, "Type mismatch: can not convert '1' to number" -- }) @@ -335,7 +335,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE x IN ('1.0'); ]], { -- <5.4> - 1, "Type mismatch: can not convert 1.0 to number" + 1, "Type mismatch: can not convert '1.0' to number" -- }) @@ -355,7 +355,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE x IN ('1.11'); ]], { -- <5.6> - 1, "Type mismatch: can not convert 1.11 to number" + 1, "Type mismatch: can not convert '1.11' to number" -- }) @@ -385,7 +385,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE '1' IN (x); ]], { -- <5.9> - 1, "Type mismatch: can not convert 1 to number" + 1, "Type mismatch: can not convert '1' to number" -- }) @@ -395,7 +395,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE '1.0' IN (x); ]], { -- <5.10> - 1, "Type mismatch: can not convert 1.0 to number" + 1, "Type mismatch: can not convert '1.0' to number" -- }) @@ -415,7 +415,7 @@ test:do_catchsql_test( SELECT x FROM t4 WHERE '1.11' IN (x); ]], { -- <5.12> - 1, "Type mismatch: can not convert 1.11 to number" + 1, "Type mismatch: can not convert '1.11' to number" -- }) diff --git a/test/sql-tap/uuid.test.lua b/test/sql-tap/uuid.test.lua index 77ba06c2d..1fc99916a 100755 --- a/test/sql-tap/uuid.test.lua +++ b/test/sql-tap/uuid.test.lua @@ -237,7 +237,7 @@ test:do_catchsql_test( [[ SELECT AVG(u) from t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to number" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_execsql_test( @@ -421,7 +421,7 @@ test:do_catchsql_test( [[ SELECT ROUND(u) from t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_execsql_test( @@ -445,7 +445,7 @@ test:do_catchsql_test( [[ SELECT SUM(u) from t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to number" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -453,7 +453,7 @@ test:do_catchsql_test( [[ SELECT TOTAL(u) from t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to number" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_execsql_test( @@ -564,7 +564,7 @@ test:do_catchsql_test( [[ SELECT cast(u AS UNSIGNED) FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to unsigned" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to unsigned" }) test:do_execsql_test( @@ -582,7 +582,7 @@ test:do_catchsql_test( [[ SELECT cast(u AS NUMBER) FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to number" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -590,7 +590,7 @@ test:do_catchsql_test( [[ SELECT cast(u AS DOUBLE) FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to double" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to double" }) test:do_catchsql_test( @@ -598,7 +598,7 @@ test:do_catchsql_test( [[ SELECT cast(u AS INTEGER) FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -606,7 +606,7 @@ test:do_catchsql_test( [[ SELECT cast(u AS BOOLEAN) FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_execsql_test( @@ -657,7 +657,7 @@ test:do_catchsql_test( [[ SELECT cast('1' AS UUID); ]], { - 1, "Type mismatch: can not convert 1 to uuid" + 1, "Type mismatch: can not convert '1' to uuid" }) test:do_catchsql_test( @@ -695,9 +695,9 @@ test:do_execsql_test( test:do_catchsql_test( "uuid-7.2.8", [[ - SELECT cast(randomblob(10) as UUID) FROM t2 LIMIT 1; + SELECT cast(x'1234567890abcdef' as UUID) FROM t2 LIMIT 1; ]], { - 1, "Type mismatch: can not convert varbinary to uuid" + 1, "Type mismatch: can not convert x'1234567890ABCDEF' to uuid" }) test:execsql([[ @@ -719,7 +719,7 @@ test:do_catchsql_test( [[ INSERT INTO tu(u) SELECT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to unsigned" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to unsigned" }) test:do_execsql_test( @@ -738,7 +738,7 @@ test:do_catchsql_test( [[ INSERT INTO tn(n) SELECT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to number" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -746,7 +746,7 @@ test:do_catchsql_test( [[ INSERT INTO td(d) SELECT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to double" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to double" }) test:do_catchsql_test( @@ -754,7 +754,7 @@ test:do_catchsql_test( [[ INSERT INTO ti(i) SELECT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -762,7 +762,7 @@ test:do_catchsql_test( [[ INSERT INTO tb(b) SELECT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_execsql_test( @@ -817,7 +817,7 @@ test:do_catchsql_test( [[ INSERT INTO tsu VALUES ('3_string_wrong', '1'); ]], { - 1, "Type mismatch: can not convert 1 to uuid" + 1, "Type mismatch: can not convert '1' to uuid" }) test:do_catchsql_test( @@ -856,9 +856,9 @@ test:do_execsql_test( test:do_catchsql_test( "uuid-8.2.8", [[ - INSERT INTO tsu VALUES ('8_varbinary', randomblob(10)); + INSERT INTO tsu VALUES ('8_varbinary', x'1234567890abcdef'); ]], { - 1, "Type mismatch: can not convert varbinary to uuid" + 1, "Type mismatch: can not convert x'1234567890ABCDEF' to uuid" }) test:execsql([[ @@ -971,7 +971,7 @@ test:do_catchsql_test( [[ SELECT -u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_catchsql_test( @@ -979,7 +979,7 @@ test:do_catchsql_test( [[ SELECT u + 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_catchsql_test( @@ -987,7 +987,7 @@ test:do_catchsql_test( [[ SELECT u - 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_catchsql_test( @@ -995,7 +995,7 @@ test:do_catchsql_test( [[ SELECT u * 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_catchsql_test( @@ -1003,7 +1003,7 @@ test:do_catchsql_test( [[ SELECT u / 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) test:do_catchsql_test( @@ -1011,7 +1011,7 @@ test:do_catchsql_test( [[ SELECT u % 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" }) -- Check that bitwise operations work with UUIDs as intended. @@ -1020,7 +1020,7 @@ test:do_catchsql_test( [[ SELECT ~u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -1028,7 +1028,7 @@ test:do_catchsql_test( [[ SELECT u >> 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -1036,7 +1036,7 @@ test:do_catchsql_test( [[ SELECT u << 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -1044,7 +1044,7 @@ test:do_catchsql_test( [[ SELECT u | 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) test:do_catchsql_test( @@ -1052,7 +1052,7 @@ test:do_catchsql_test( [[ SELECT u & 1 FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to integer" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to integer" }) -- Check that logical operations work with UUIDs as intended. @@ -1061,7 +1061,7 @@ test:do_catchsql_test( [[ SELECT NOT u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_catchsql_test( @@ -1069,7 +1069,7 @@ test:do_catchsql_test( [[ SELECT u AND true FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_catchsql_test( @@ -1077,7 +1077,7 @@ test:do_catchsql_test( [[ SELECT u OR true FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_catchsql_test( @@ -1085,7 +1085,7 @@ test:do_catchsql_test( [[ SELECT true AND u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) test:do_catchsql_test( @@ -1093,7 +1093,7 @@ test:do_catchsql_test( [[ SELECT true OR u FROM t2; ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111 to boolean" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to boolean" }) -- Check that comparison with UUID works as intended. @@ -1296,7 +1296,7 @@ test:do_catchsql_test( [[ SELECT uuid('asd'); ]], { - 1, "Type mismatch: can not convert asd to integer" + 1, "Type mismatch: can not convert 'asd' to integer" }) test:do_catchsql_test( @@ -1322,7 +1322,7 @@ test:do_catchsql_test( [[ SELECT CAST('11111111-1111-1111-1111-111111111111111222222222' AS UUID); ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-111111111111111222222222 to uuid" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111111222222222' to uuid" }) test:do_catchsql_test( @@ -1330,7 +1330,7 @@ test:do_catchsql_test( [[ SELECT CAST('11111111-1111-1111-1111-11111' AS UUID); ]], { - 1, "Type mismatch: can not convert 11111111-1111-1111-1111-11111 to uuid" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-11111' to uuid" }) test:execsql([[ diff --git a/test/sql/boolean.result b/test/sql/boolean.result index 177a39fb9..dbd31fbb5 100644 --- a/test/sql/boolean.result +++ b/test/sql/boolean.result @@ -5092,7 +5092,7 @@ INSERT INTO t9 VALUES ('AsdF'); SELECT true AND 'abc'; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT false AND 'abc'; | --- @@ -5105,17 +5105,17 @@ SELECT false AND 'abc'; SELECT true OR 'abc'; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT false OR 'abc'; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT 'abc' AND true; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT 'abc' AND false; | --- @@ -5128,59 +5128,59 @@ SELECT 'abc' AND false; SELECT 'abc' OR true; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT 'abc' OR false; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a1, a1 AND 'abc' FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a1, a1 OR 'abc' FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a1, 'abc' AND a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a1, 'abc' OR a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a2, a2 AND 'abc' FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a2, a2 OR 'abc' FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a2, 'abc' AND a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT a2, 'abc' OR a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert abc to boolean' + | - 'Type mismatch: can not convert ''abc'' to boolean' | ... SELECT d, true AND d FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT d, false AND d FROM t9; | --- @@ -5195,17 +5195,17 @@ SELECT d, false AND d FROM t9; SELECT d, true OR d FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT d, false OR d FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT d, d AND true FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT d, d AND false FROM t9; | --- @@ -5220,53 +5220,53 @@ SELECT d, d AND false FROM t9; SELECT d, d OR true FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT d, d OR false FROM t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a1, d, a1 AND d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a1, d, a1 OR d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a1, d, d AND a1 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a1, d, d OR a1 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a2, d, a2 AND d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a2, d, a2 OR d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a2, d, d AND a2 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT a2, d, d OR a2 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert AsdF to boolean' + | - 'Type mismatch: can not convert ''AsdF'' to boolean' | ... SELECT true > 'abc'; @@ -5467,7 +5467,7 @@ INSERT INTO t9 VALUES ('TRUE'), ('true'), ('FALSE'), ('false'); SELECT true AND 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT false AND 'TRUE'; | --- @@ -5480,17 +5480,17 @@ SELECT false AND 'TRUE'; SELECT true OR 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT false OR 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT 'TRUE' AND true; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT 'TRUE' AND false; | --- @@ -5503,59 +5503,59 @@ SELECT 'TRUE' AND false; SELECT 'TRUE' OR true; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT 'TRUE' OR false; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, a1 AND 'TRUE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, a1 OR 'TRUE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, 'TRUE' AND a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, 'TRUE' OR a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, a2 AND 'TRUE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, a2 OR 'TRUE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, 'TRUE' AND a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, 'TRUE' OR a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, true AND d FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, false AND d FROM t9 WHERE d = 'TRUE'; | --- @@ -5570,17 +5570,17 @@ SELECT d, false AND d FROM t9 WHERE d = 'TRUE'; SELECT d, true OR d FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, false OR d FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, d AND true FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, d AND false FROM t9 WHERE d = 'TRUE'; | --- @@ -5595,59 +5595,59 @@ SELECT d, d AND false FROM t9 WHERE d = 'TRUE'; SELECT d, d OR true FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT d, d OR false FROM t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, d, a1 AND d FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, d, a1 OR d FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, d, d AND a1 FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a1, d, d OR a1 FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, d, a2 AND d FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, d, a2 OR d FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, d, d AND a2 FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT a2, d, d OR a2 FROM t6, t9 WHERE d = 'TRUE'; | --- | - null - | - 'Type mismatch: can not convert TRUE to boolean' + | - 'Type mismatch: can not convert ''TRUE'' to boolean' | ... SELECT true AND 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT false AND 'true'; | --- @@ -5660,17 +5660,17 @@ SELECT false AND 'true'; SELECT true OR 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT false OR 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT 'true' AND true; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT 'true' AND false; | --- @@ -5683,59 +5683,59 @@ SELECT 'true' AND false; SELECT 'true' OR true; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT 'true' OR false; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, a1 AND 'true' FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, a1 OR 'true' FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, 'true' AND a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, 'true' OR a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, a2 AND 'true' FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, a2 OR 'true' FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, 'true' AND a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, 'true' OR a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, true AND d FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, false AND d FROM t9 WHERE d = 'true'; | --- @@ -5750,17 +5750,17 @@ SELECT d, false AND d FROM t9 WHERE d = 'true'; SELECT d, true OR d FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, false OR d FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, d AND true FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, d AND false FROM t9 WHERE d = 'true'; | --- @@ -5775,59 +5775,59 @@ SELECT d, d AND false FROM t9 WHERE d = 'true'; SELECT d, d OR true FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT d, d OR false FROM t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, d, a1 AND d FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, d, a1 OR d FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, d, d AND a1 FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a1, d, d OR a1 FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, d, a2 AND d FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, d, a2 OR d FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, d, d AND a2 FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT a2, d, d OR a2 FROM t6, t9 WHERE d = 'true'; | --- | - null - | - 'Type mismatch: can not convert true to boolean' + | - 'Type mismatch: can not convert ''true'' to boolean' | ... SELECT true AND 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT false AND 'FALSE'; | --- @@ -5840,17 +5840,17 @@ SELECT false AND 'FALSE'; SELECT true OR 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT false OR 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT 'FALSE' AND true; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT 'FALSE' AND false; | --- @@ -5863,59 +5863,59 @@ SELECT 'FALSE' AND false; SELECT 'FALSE' OR true; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT 'FALSE' OR false; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, a1 AND 'FALSE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, a1 OR 'FALSE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, 'FALSE' AND a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, 'FALSE' OR a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, a2 AND 'FALSE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, a2 OR 'FALSE' FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, 'FALSE' AND a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, 'FALSE' OR a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, true AND d FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, false AND d FROM t9 WHERE d = 'FALSE'; | --- @@ -5930,17 +5930,17 @@ SELECT d, false AND d FROM t9 WHERE d = 'FALSE'; SELECT d, true OR d FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, false OR d FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, d AND true FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, d AND false FROM t9 WHERE d = 'FALSE'; | --- @@ -5955,59 +5955,59 @@ SELECT d, d AND false FROM t9 WHERE d = 'FALSE'; SELECT d, d OR true FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT d, d OR false FROM t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, d, a1 AND d FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, d, a1 OR d FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, d, d AND a1 FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a1, d, d OR a1 FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, d, a2 AND d FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, d, a2 OR d FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, d, d AND a2 FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT a2, d, d OR a2 FROM t6, t9 WHERE d = 'FALSE'; | --- | - null - | - 'Type mismatch: can not convert FALSE to boolean' + | - 'Type mismatch: can not convert ''FALSE'' to boolean' | ... SELECT true AND 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT false AND 'false'; | --- @@ -6020,17 +6020,17 @@ SELECT false AND 'false'; SELECT true OR 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT false OR 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT 'false' AND true; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT 'false' AND false; | --- @@ -6043,59 +6043,59 @@ SELECT 'false' AND false; SELECT 'false' OR true; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT 'false' OR false; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, a1 AND 'false' FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, a1 OR 'false' FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, 'false' AND a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, 'false' OR a1 FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, a2 AND 'false' FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, a2 OR 'false' FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, 'false' AND a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, 'false' OR a2 FROM t6; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, true AND d FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, false AND d FROM t9 WHERE d = 'false'; | --- @@ -6110,17 +6110,17 @@ SELECT d, false AND d FROM t9 WHERE d = 'false'; SELECT d, true OR d FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, false OR d FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, d AND true FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, d AND false FROM t9 WHERE d = 'false'; | --- @@ -6135,53 +6135,53 @@ SELECT d, d AND false FROM t9 WHERE d = 'false'; SELECT d, d OR true FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT d, d OR false FROM t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, d, a1 AND d FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, d, a1 OR d FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, d, d AND a1 FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a1, d, d OR a1 FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, d, a2 AND d FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, d, a2 OR d FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, d, d AND a2 FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... SELECT a2, d, d OR a2 FROM t6, t9 WHERE d = 'false'; | --- | - null - | - 'Type mismatch: can not convert false to boolean' + | - 'Type mismatch: can not convert ''false'' to boolean' | ... -- Cleaning. diff --git a/test/sql/integer-overflow.result b/test/sql/integer-overflow.result index a56fb2412..c5de00fd5 100644 --- a/test/sql/integer-overflow.result +++ b/test/sql/integer-overflow.result @@ -106,7 +106,7 @@ box.execute('SELECT CAST(\'9223372036854775808\' AS INTEGER);') box.execute('SELECT CAST(\'18446744073709551616\' AS INTEGER);') --- - null -- 'Type mismatch: can not convert 18446744073709551616 to integer' +- 'Type mismatch: can not convert ''18446744073709551616'' to integer' ... -- Due to inexact represantation of large integers in terms of -- floating point numbers, numerics with value < UINT64_MAX diff --git a/test/sql/persistency.result b/test/sql/persistency.result index 0e259edef..fab94301d 100644 --- a/test/sql/persistency.result +++ b/test/sql/persistency.result @@ -371,7 +371,7 @@ box.execute("SELECT \"name\", \"opts\" FROM \"_trigger\""); box.execute("INSERT INTO foobar VALUES ('foobar trigger test', 8888)") --- - null -- 'Type mismatch: can not convert foobar trigger test to integer' +- 'Type mismatch: can not convert ''foobar trigger test'' to integer' ... box.execute("SELECT * FROM barfoo WHERE foo = 9999"); --- diff --git a/test/sql/types.result b/test/sql/types.result index a46967158..219559619 100644 --- a/test/sql/types.result +++ b/test/sql/types.result @@ -270,7 +270,7 @@ box.space.T1:drop() box.execute("SELECT CAST('1.123' AS INTEGER);") --- - null -- 'Type mismatch: can not convert 1.123 to integer' +- 'Type mismatch: can not convert ''1.123'' to integer' ... box.execute("CREATE TABLE t1 (f TEXT PRIMARY KEY);") --- @@ -283,7 +283,7 @@ box.execute("INSERT INTO t1 VALUES('0.0'), ('1.5'), ('3.9312453');") box.execute("SELECT CAST(f AS INTEGER) FROM t1;") --- - null -- 'Type mismatch: can not convert 0.0 to integer' +- 'Type mismatch: can not convert ''0.0'' to integer' ... box.space.T1:drop() --- @@ -339,12 +339,12 @@ box.execute("INSERT INTO tboolean VALUES (TRUE);") box.execute("SELECT * FROM tboolean WHERE s1 = x'44';") --- - null -- 'Type mismatch: can not convert varbinary to boolean' +- 'Type mismatch: can not convert x''44'' to boolean' ... box.execute("SELECT * FROM tboolean WHERE s1 = 'abc';") --- - null -- 'Type mismatch: can not convert abc to boolean' +- 'Type mismatch: can not convert ''abc'' to boolean' ... box.execute("SELECT * FROM tboolean WHERE s1 = 1;") --- @@ -632,7 +632,7 @@ box.execute("SELECT 1 LIMIT 1 OFFSET 18446744073709551614;") box.execute("SELECT CAST('18446744073' || '709551616' AS INTEGER);") --- - null -- 'Type mismatch: can not convert 18446744073709551616 to integer' +- 'Type mismatch: can not convert ''18446744073709551616'' to integer' ... box.execute("SELECT CAST('18446744073' || '709551615' AS INTEGER);") --- @@ -1122,7 +1122,7 @@ box.execute("SELECT CAST('123' AS UNSIGNED);") box.execute("SELECT CAST('-123' AS UNSIGNED);") --- - null -- 'Type mismatch: can not convert -123 to unsigned' +- 'Type mismatch: can not convert ''-123'' to unsigned' ... box.space.T1:drop() --- @@ -1231,7 +1231,7 @@ box.execute("INSERT INTO t VALUES(1, true);") box.execute("INSERT INTO t VALUES(1, 'asd');") --- - null -- 'Type mismatch: can not convert asd to varbinary' +- 'Type mismatch: can not convert ''asd'' to varbinary' ... box.execute("INSERT INTO t VALUES(1, x'616263');") --- @@ -1265,17 +1265,17 @@ box.execute("SELECT * FROM t WHERE v = x'616263'") box.execute("SELECT sum(v) FROM t;") --- - null -- 'Type mismatch: can not convert varbinary to number' +- 'Type mismatch: can not convert x''616263'' to number' ... box.execute("SELECT avg(v) FROM t;") --- - null -- 'Type mismatch: can not convert varbinary to number' +- 'Type mismatch: can not convert x''616263'' to number' ... box.execute("SELECT total(v) FROM t;") --- - null -- 'Type mismatch: can not convert varbinary to number' +- 'Type mismatch: can not convert x''616263'' to number' ... box.execute("SELECT min(v) FROM t;") --- @@ -1722,7 +1722,7 @@ box.execute("SELECT CAST(true AS DOUBLE);") box.execute("SELECT CAST('asd' AS DOUBLE);") --- - null -- 'Type mismatch: can not convert asd to double' +- 'Type mismatch: can not convert ''asd'' to double' ... box.execute("SELECT CAST('1' AS DOUBLE);") --- @@ -1743,12 +1743,12 @@ box.execute("SELECT CAST('1.123' AS DOUBLE);") box.execute("SELECT CAST(x'' AS DOUBLE);") --- - null -- 'Type mismatch: can not convert varbinary to double' +- 'Type mismatch: can not convert x'''' to double' ... box.execute("SELECT CAST(x'35' AS DOUBLE);") --- - null -- 'Type mismatch: can not convert varbinary to double' +- 'Type mismatch: can not convert x''35'' to double' ... box.execute("SELECT CAST(CAST(x'35' AS STRING) AS DOUBLE);") --- @@ -2209,12 +2209,12 @@ box.execute([[INSERT INTO ti(i) VALUES (true);]]) box.execute([[INSERT INTO ti(i) VALUES ('33');]]) --- - null -- 'Type mismatch: can not convert 33 to integer' +- 'Type mismatch: can not convert ''33'' to integer' ... box.execute([[INSERT INTO ti(i) VALUES (X'3434');]]) --- - null -- 'Type mismatch: can not convert varbinary to integer' +- 'Type mismatch: can not convert x''3434'' to integer' ... box.execute([[SELECT * FROM ti;]]) --- @@ -2259,12 +2259,12 @@ box.execute([[INSERT INTO td(d) VALUES (true);]]) box.execute([[INSERT INTO td(d) VALUES ('33');]]) --- - null -- 'Type mismatch: can not convert 33 to double' +- 'Type mismatch: can not convert ''33'' to double' ... box.execute([[INSERT INTO td(d) VALUES (X'3434');]]) --- - null -- 'Type mismatch: can not convert varbinary to double' +- 'Type mismatch: can not convert x''3434'' to double' ... box.execute([[SELECT * FROM td;]]) --- @@ -2303,12 +2303,12 @@ box.execute([[INSERT INTO tb(b) VALUES (true);]]) box.execute([[INSERT INTO tb(b) VALUES ('33');]]) --- - null -- 'Type mismatch: can not convert 33 to boolean' +- 'Type mismatch: can not convert ''33'' to boolean' ... box.execute([[INSERT INTO tb(b) VALUES (X'3434');]]) --- - null -- 'Type mismatch: can not convert varbinary to boolean' +- 'Type mismatch: can not convert x''3434'' to boolean' ... box.execute([[SELECT * FROM tb;]]) --- @@ -2351,7 +2351,7 @@ box.execute([[INSERT INTO tt(t) VALUES ('33');]]) box.execute([[INSERT INTO tt(t) VALUES (X'3434');]]) --- - null -- 'Type mismatch: can not convert varbinary to string' +- 'Type mismatch: can not convert x''3434'' to string' ... box.execute([[SELECT * FROM tt;]]) --- @@ -2388,7 +2388,7 @@ box.execute([[INSERT INTO tv(v) VALUES (true);]]) box.execute([[INSERT INTO tv(v) VALUES ('33');]]) --- - null -- 'Type mismatch: can not convert 33 to varbinary' +- 'Type mismatch: can not convert ''33'' to varbinary' ... box.execute([[INSERT INTO tv(v) VALUES (X'3434');]]) --- @@ -2562,12 +2562,12 @@ box.execute([[UPDATE ti SET i = true WHERE a = 1;]]) box.execute([[UPDATE ti SET i = '33' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert 33 to integer' +- 'Type mismatch: can not convert ''33'' to integer' ... box.execute([[UPDATE ti SET i = X'3434' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert varbinary to integer' +- 'Type mismatch: can not convert x''3434'' to integer' ... box.execute([[SELECT * FROM ti;]]) --- @@ -2603,12 +2603,12 @@ box.execute([[UPDATE td SET d = true WHERE a = 1;]]) box.execute([[UPDATE td SET d = '33' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert 33 to double' +- 'Type mismatch: can not convert ''33'' to double' ... box.execute([[UPDATE td SET d = X'3434' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert varbinary to double' +- 'Type mismatch: can not convert x''3434'' to double' ... box.execute([[SELECT * FROM td;]]) --- @@ -2641,12 +2641,12 @@ box.execute([[UPDATE tb SET b = true WHERE a = 1;]]) box.execute([[UPDATE tb SET b = '33' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert 33 to boolean' +- 'Type mismatch: can not convert ''33'' to boolean' ... box.execute([[UPDATE tb SET b = X'3434' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert varbinary to boolean' +- 'Type mismatch: can not convert x''3434'' to boolean' ... box.execute([[SELECT * FROM tb;]]) --- @@ -2684,7 +2684,7 @@ box.execute([[UPDATE tt SET t = '33' WHERE a = 1;]]) box.execute([[UPDATE tt SET t = X'3434' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert varbinary to string' +- 'Type mismatch: can not convert x''3434'' to string' ... box.execute([[SELECT * FROM tt;]]) --- @@ -2718,7 +2718,7 @@ box.execute([[UPDATE tv SET v = true WHERE a = 1;]]) box.execute([[UPDATE tv SET v = '33' WHERE a = 1;]]) --- - null -- 'Type mismatch: can not convert 33 to varbinary' +- 'Type mismatch: can not convert ''33'' to varbinary' ... box.execute([[UPDATE tv SET v = X'3434' WHERE a = 1;]]) --- Third patch: commit 8ca070644eb6f10db748af6801ddaaec3bbef5f8 Author: Mergen Imeev Date: Sun Jul 4 21:35:43 2021 +0300 sql: use proper type names in error descriptions Prior to this patch, the type mismatch error description and the inconsistent types error description in some cases displayed type names that were different from the default ones. After this patch, all types in these descriptions are described using the default names. Part of #6176 diff --git a/src/box/sql/func.c b/src/box/sql/func.c index f93ae867d..e4832f46d 100644 --- a/src/box/sql/func.c +++ b/src/box/sql/func.c @@ -324,7 +324,7 @@ position_func(struct sql_context *context, int argc, struct Mem **argv) inconsistent_type_arg = haystack; if (inconsistent_type_arg != NULL) { diag_set(ClientError, ER_INCONSISTENT_TYPES, - "text or varbinary", + "string or varbinary", mem_type_to_str(inconsistent_type_arg)); context->is_aborted = true; return; @@ -590,7 +590,7 @@ roundFunc(sql_context * context, int argc, sql_value ** argv) return; if (!mem_is_num(argv[0]) && !mem_is_str(argv[0])) { diag_set(ClientError, ER_SQL_TYPE_MISMATCH, - mem_str(argv[0]), "numeric"); + mem_str(argv[0]), "number"); context->is_aborted = true; return; } @@ -650,7 +650,7 @@ case_type##ICUFunc(sql_context *context, int argc, sql_value **argv) \ UNUSED_PARAMETER(argc); \ if (mem_is_bin(argv[0]) || mem_is_map(argv[0]) || \ mem_is_array(argv[0])) { \ - diag_set(ClientError, ER_INCONSISTENT_TYPES, "text", \ + diag_set(ClientError, ER_INCONSISTENT_TYPES, "string", \ "varbinary"); \ context->is_aborted = true; \ return; \ @@ -733,7 +733,7 @@ randomBlob(sql_context * context, int argc, sql_value ** argv) if (mem_is_bin(argv[0]) || mem_is_map(argv[0]) || mem_is_array(argv[0])) { diag_set(ClientError, ER_SQL_TYPE_MISMATCH, - mem_str(argv[0]), "numeric"); + mem_str(argv[0]), "number"); context->is_aborted = true; return; } @@ -987,7 +987,7 @@ likeFunc(sql_context *context, int argc, sql_value **argv) char *inconsistent_type = rhs_type != MP_STR ? mem_type_to_str(argv[0]) : mem_type_to_str(argv[1]); - diag_set(ClientError, ER_INCONSISTENT_TYPES, "text", + diag_set(ClientError, ER_INCONSISTENT_TYPES, "string", inconsistent_type); context->is_aborted = true; return; @@ -1624,7 +1624,7 @@ soundexFunc(sql_context * context, int argc, sql_value ** argv) if (mem_is_bin(argv[0]) || mem_is_map(argv[0]) || mem_is_array(argv[0])) { diag_set(ClientError, ER_SQL_TYPE_MISMATCH, - mem_str(argv[0]), "text"); + mem_str(argv[0]), "string"); context->is_aborted = true; return; } diff --git a/src/box/sql/mem.c b/src/box/sql/mem.c index 3bbff9897..c4375e1ea 100644 --- a/src/box/sql/mem.c +++ b/src/box/sql/mem.c @@ -1450,12 +1450,12 @@ mem_concat(struct Mem *a, struct Mem *b, struct Mem *result) /* Concatenation operation can be applied only to strings and blobs. */ if (((b->type & (MEM_TYPE_STR | MEM_TYPE_BIN)) == 0)) { diag_set(ClientError, ER_INCONSISTENT_TYPES, - "text or varbinary", mem_type_to_str(b)); + "string or varbinary", mem_type_to_str(b)); return -1; } if (((a->type & (MEM_TYPE_STR | MEM_TYPE_BIN)) == 0)) { diag_set(ClientError, ER_INCONSISTENT_TYPES, - "text or varbinary", mem_type_to_str(a)); + "string or varbinary", mem_type_to_str(a)); return -1; } @@ -1544,12 +1544,12 @@ arithmetic_prepare(const struct Mem *left, const struct Mem *right, { if (get_number(right, b) != 0) { diag_set(ClientError, ER_SQL_TYPE_MISMATCH, mem_str(right), - "numeric"); + "number"); return -1; } if (get_number(left, a) != 0) { diag_set(ClientError, ER_SQL_TYPE_MISMATCH, mem_str(left), - "numeric"); + "number"); return -1; } assert(a->type != 0 && b->type != 0); @@ -2065,15 +2065,17 @@ mem_type_to_str(const struct Mem *p) case MEM_TYPE_NULL: return "NULL"; case MEM_TYPE_STR: - return "text"; + return "string"; case MEM_TYPE_INT: return "integer"; case MEM_TYPE_UINT: return "unsigned"; case MEM_TYPE_DOUBLE: - return "real"; + return "double"; case MEM_TYPE_ARRAY: + return "array"; case MEM_TYPE_MAP: + return "map"; case MEM_TYPE_BIN: return "varbinary"; case MEM_TYPE_BOOL: diff --git a/src/box/sql/vdbe.c b/src/box/sql/vdbe.c index 32d02d96e..03f420bca 100644 --- a/src/box/sql/vdbe.c +++ b/src/box/sql/vdbe.c @@ -1674,7 +1674,7 @@ case OP_Ge: { /* same as TK_GE, jump, in1, in3 */ mem_cast_implicit_old(pIn3, type) != 0 ? mem_str(pIn3) : mem_str(pIn1); diag_set(ClientError, ER_SQL_TYPE_MISMATCH, str, - "numeric"); + "number"); goto abort_due_to_error; } } else { diff --git a/test/sql-tap/func.test.lua b/test/sql-tap/func.test.lua index ae6bc9ddd..66e525871 100755 --- a/test/sql-tap/func.test.lua +++ b/test/sql-tap/func.test.lua @@ -2931,7 +2931,7 @@ test:do_catchsql_test( SELECT ROUND(X'FF') ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) @@ -2941,7 +2941,7 @@ test:do_catchsql_test( SELECT RANDOMBLOB(X'FF') ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) @@ -2951,7 +2951,7 @@ test:do_catchsql_test( SELECT SOUNDEX(X'FF') ]], { -- - 1, "Type mismatch: can not convert x'FF' to text" + 1, "Type mismatch: can not convert x'FF' to string" -- }) diff --git a/test/sql-tap/index1.test.lua b/test/sql-tap/index1.test.lua index e03e284aa..9e57639cc 100755 --- a/test/sql-tap/index1.test.lua +++ b/test/sql-tap/index1.test.lua @@ -778,7 +778,7 @@ test:do_catchsql_test( SELECT c FROM t6 WHERE a>123; ]], { -- - 1, "Type mismatch: can not convert '' to numeric" + 1, "Type mismatch: can not convert '' to number" -- }) @@ -788,7 +788,7 @@ test:do_catchsql_test( SELECT c FROM t6 WHERE a>=123; ]], { -- - 1, "Type mismatch: can not convert '' to numeric" + 1, "Type mismatch: can not convert '' to number" -- }) diff --git a/test/sql-tap/position.test.lua b/test/sql-tap/position.test.lua index 506efe0f4..dd4fa62d0 100755 --- a/test/sql-tap/position.test.lua +++ b/test/sql-tap/position.test.lua @@ -228,7 +228,7 @@ test:do_test( return test:catchsql "SELECT position(34, 12345);" end, { -- - 1, "Inconsistent types: expected text or varbinary got unsigned" + 1, "Inconsistent types: expected string or varbinary got unsigned" -- }) @@ -238,7 +238,7 @@ test:do_test( return test:catchsql "SELECT position(34, 123456.78);" end, { -- - 1, "Inconsistent types: expected text or varbinary got real" + 1, "Inconsistent types: expected string or varbinary got double" -- }) @@ -248,7 +248,7 @@ test:do_test( return test:catchsql "SELECT position(x'3334', 123456.78);" end, { -- - 1, "Inconsistent types: expected text or varbinary got real" + 1, "Inconsistent types: expected string or varbinary got double" -- }) @@ -554,7 +554,7 @@ test:do_test( return test:catchsql("SELECT position('x', x'78c3a4e282ac79');") end, { -- - 1, "Inconsistent types: expected text got varbinary" + 1, "Inconsistent types: expected string got varbinary" -- }) @@ -564,7 +564,7 @@ test:do_test( return test:catchsql "SELECT position('y', x'78c3a4e282ac79');" end, { -- - 1, "Inconsistent types: expected text got varbinary" + 1, "Inconsistent types: expected string got varbinary" -- }) @@ -614,7 +614,7 @@ test:do_test( return test:catchsql "SELECT position(x'79', 'xä€y');" end, { -- - 1, "Inconsistent types: expected varbinary got text" + 1, "Inconsistent types: expected varbinary got string" -- }) @@ -624,7 +624,7 @@ test:do_test( return test:catchsql "SELECT position(x'a4', 'xä€y');" end, { -- - 1, "Inconsistent types: expected varbinary got text" + 1, "Inconsistent types: expected varbinary got string" -- }) @@ -634,7 +634,7 @@ test:do_test( return test:catchsql "SELECT position('y', x'78c3a4e282ac79');" end, { -- - 1, "Inconsistent types: expected text got varbinary" + 1, "Inconsistent types: expected string got varbinary" -- }) diff --git a/test/sql-tap/select1.test.lua b/test/sql-tap/select1.test.lua index 1a7a4ee82..57c5c2cb3 100755 --- a/test/sql-tap/select1.test.lua +++ b/test/sql-tap/select1.test.lua @@ -320,7 +320,7 @@ test:do_catchsql_test( SELECT count(*),count(a),count(b) FROM t4 WHERE b=5 ]], { -- - 1, "Type mismatch: can not convert 'This is a string that is too big to fit inside a NBFS buffer' to numeric" + 1, "Type mismatch: can not convert 'This is a string that is too big to fit inside a NBFS buffer' to number" -- }) diff --git a/test/sql-tap/sql-errors.test.lua b/test/sql-tap/sql-errors.test.lua index 52276c27b..66dc77fa1 100755 --- a/test/sql-tap/sql-errors.test.lua +++ b/test/sql-tap/sql-errors.test.lua @@ -696,7 +696,7 @@ test:do_catchsql_test( SELECT X'ff' + 1; ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) @@ -706,7 +706,7 @@ test:do_catchsql_test( SELECT X'ff' - 1; ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) @@ -716,7 +716,7 @@ test:do_catchsql_test( SELECT X'ff' * 1; ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) @@ -726,7 +726,7 @@ test:do_catchsql_test( SELECT X'ff' / 1; ]], { -- - 1, "Type mismatch: can not convert x'FF' to numeric" + 1, "Type mismatch: can not convert x'FF' to number" -- }) diff --git a/test/sql-tap/uuid.test.lua b/test/sql-tap/uuid.test.lua index 1fc99916a..c9e1b4fcc 100755 --- a/test/sql-tap/uuid.test.lua +++ b/test/sql-tap/uuid.test.lua @@ -337,7 +337,7 @@ test:do_catchsql_test( [[ SELECT u LIKE 'a' from t2; ]], { - 1, "Inconsistent types: expected text got uuid" + 1, "Inconsistent types: expected string got uuid" }) test:do_execsql_test( @@ -395,7 +395,7 @@ test:do_catchsql_test( [[ SELECT POSITION(u, '1') from t2; ]], { - 1, "Inconsistent types: expected text or varbinary got uuid" + 1, "Inconsistent types: expected string or varbinary got uuid" }) test:do_execsql_test( @@ -421,7 +421,7 @@ test:do_catchsql_test( [[ SELECT ROUND(u) from t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_execsql_test( @@ -505,7 +505,7 @@ test:do_catchsql_test( [[ SELECT u || u from t2; ]], { - 1, "Inconsistent types: expected text or varbinary got uuid" + 1, "Inconsistent types: expected string or varbinary got uuid" }) local func = {language = 'Lua', body = 'function(x) return type(x) end', @@ -971,7 +971,7 @@ test:do_catchsql_test( [[ SELECT -u FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -979,7 +979,7 @@ test:do_catchsql_test( [[ SELECT u + 1 FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -987,7 +987,7 @@ test:do_catchsql_test( [[ SELECT u - 1 FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -995,7 +995,7 @@ test:do_catchsql_test( [[ SELECT u * 1 FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -1003,7 +1003,7 @@ test:do_catchsql_test( [[ SELECT u / 1 FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) test:do_catchsql_test( @@ -1011,7 +1011,7 @@ test:do_catchsql_test( [[ SELECT u % 1 FROM t2; ]], { - 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to numeric" + 1, "Type mismatch: can not convert '11111111-1111-1111-1111-111111111111' to number" }) -- Check that bitwise operations work with UUIDs as intended. @@ -1118,7 +1118,7 @@ test:do_catchsql_test( [[ SELECT u > '1' FROM t2; ]], { - 1, "Type mismatch: can not convert text to uuid" + 1, "Type mismatch: can not convert string to uuid" }) test:do_catchsql_test( @@ -1126,7 +1126,7 @@ test:do_catchsql_test( [[ SELECT u > 1.5 FROM t2; ]], { - 1, "Type mismatch: can not convert real to uuid" + 1, "Type mismatch: can not convert double to uuid" }) test:do_catchsql_test( @@ -1182,7 +1182,7 @@ test:do_catchsql_test( [[ SELECT u = '1' FROM t2; ]], { - 1, "Type mismatch: can not convert text to uuid" + 1, "Type mismatch: can not convert string to uuid" }) test:do_catchsql_test( @@ -1190,7 +1190,7 @@ test:do_catchsql_test( [[ SELECT u = 1.5 FROM t2; ]], { - 1, "Type mismatch: can not convert real to uuid" + 1, "Type mismatch: can not convert double to uuid" }) test:do_catchsql_test( diff --git a/test/sql/boolean.result b/test/sql/boolean.result index dbd31fbb5..320525d36 100644 --- a/test/sql/boolean.result +++ b/test/sql/boolean.result @@ -138,12 +138,12 @@ INSERT INTO ts(s) VALUES ('abc'), (12.5); SELECT s FROM ts WHERE s = true; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT s FROM ts WHERE s < true; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT s FROM ts WHERE s IN (true, 1, 'abcd'); | --- @@ -1122,245 +1122,245 @@ SELECT a, a1, a OR a1 FROM t, t6; SELECT -true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT -false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT -a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true + true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true + false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT false + true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false + false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true - true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true - false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT false - true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false - false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true * true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true * false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT false * true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false * false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true / true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true / false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT false / true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false / false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true % true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true % false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT false % true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false % false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, true + a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, false + a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, true - a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, false - a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, true * a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, false * a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, true / a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, false / a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, true % a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, false % a FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a + true FROM t; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a, a + false FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a - true FROM t; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a, a - false FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a * true FROM t; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a, a * false FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a / true FROM t; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a, a / false FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a % true FROM t; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a, a % false FROM t; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a1, a + a1 FROM t, t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a1, a - a1 FROM t, t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a1, a * a1 FROM t, t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a1, a / a1 FROM t, t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a, a1, a % a1 FROM t, t6; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT ~true; @@ -1560,64 +1560,64 @@ SELECT a, a1, a >> a1 FROM t, t6; SELECT true || true; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT true || false; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT false || true; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT false || false; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a, true || a FROM t; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a, false || a FROM t; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a, a || true FROM t; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a, a || false FROM t; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a1, a1 || a1 FROM t6; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a2, a2 || a2 FROM t6; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a1, a2, a1 || a1 FROM t6; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT a1, a2, a2 || a2 FROM t6; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... -- Check comparisons. @@ -2643,405 +2643,405 @@ SELECT a2, b, b OR a2 FROM t6, t7; SELECT true + 2; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false + 2; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true - 2; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false - 2; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true * 2; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false * 2; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true / 2; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false / 2; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true % 2; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false % 2; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2 + true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2 + false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2 - true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2 - false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2 * true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2 * false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2 / true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2 / false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2 % true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2 % false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 + 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 - 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 * 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 / 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 % 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2 + a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2 - a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2 * a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2 / a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2 % a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a2, a2 + 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 - 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 * 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 / 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 % 2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2 + a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2 - a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2 * a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2 / a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2 % a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, true + b FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, false + b FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, true - b FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, false - b FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, true * b FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, false * b FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, true / b FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, false / b FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, true % b FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, false % b FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, b + true FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, b + false FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, b - true FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, b - false FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, b * true FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, b * false FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, b / true FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, b / false FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT b, b % true FROM t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT b, b % false FROM t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, a1 + b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, a1 - b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, a1 * b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, a1 / b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, a1 % b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, b + a1 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, b - a1 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, b * a1 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, b / a1 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, b, b % a1 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a2, b, a2 + b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, a2 - b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, a2 * b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, a2 / b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, a2 % b FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, b + a2 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, b - a2 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, b * a2 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, b / a2 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, b, b % a2 FROM t6, t7; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true & 2; @@ -4112,897 +4112,897 @@ SELECT a2, c, c OR a2 FROM t6, t8; SELECT true + 2.3; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false + 2.3; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true - 2.3; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false - 2.3; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true * 2.3; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false * 2.3; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true / 2.3; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false / 2.3; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT true % 2.3; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT false % 2.3; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2.3 + true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2.3 + false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2.3 - true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2.3 - false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2.3 * true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2.3 * false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2.3 / true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2.3 / false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT 2.3 % true; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT 2.3 % false; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 + 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 - 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 * 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 / 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, a1 % 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2.3 + a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2.3 - a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2.3 * a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2.3 / a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, 2.3 % a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a2, a2 + 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 - 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 * 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 / 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, a2 % 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2.3 + a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2.3 - a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2.3 * a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2.3 / a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, 2.3 % a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, true + c FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, false + c FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, true - c FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, false - c FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, true * c FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, false * c FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, true / c FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, false / c FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, true % c FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, false % c FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, c + true FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, c + false FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, c - true FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, c - false FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, c * true FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, c * false FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, c / true FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, c / false FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT c, c % true FROM t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT c, c % false FROM t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, a1 + c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, a1 - c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, a1 * c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, a1 / c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, a1 % c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, c + a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, c - a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, c * a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, c / a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a1, c, c % a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert FALSE to numeric' + | - 'Type mismatch: can not convert FALSE to number' | ... SELECT a2, c, a2 + c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, a2 - c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, a2 * c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, a2 / c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, a2 % c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, c + a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, c - a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, c * a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, c / a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT a2, c, c % a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert TRUE to numeric' + | - 'Type mismatch: can not convert TRUE to number' | ... SELECT true > 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false > 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true < 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false < 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 > true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 > false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 < true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 < false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 > 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 < 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 > a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 < a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 > 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 < 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 > a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 < a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true > c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false > c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true < c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false < c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c > true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c > false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c < true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c < false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 > c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 < c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c > a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c < a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 > c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 < c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c > a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c < a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true >= 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false >= 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true <= 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false <= 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 >= true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 >= false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 <= true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 <= false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 >= 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 <= 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 >= a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 <= a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 >= 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 <= 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 >= a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 <= a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true >= c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false >= c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true <= c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false <= c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c >= true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c >= false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c <= true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c <= false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 >= c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 <= c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c >= a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c <= a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 >= c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 <= c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c >= a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c <= a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true == 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false == 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true != 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false != 2.3; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 == true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 == false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 != true; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT 2.3 != false; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 == 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 != 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 == a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, 2.3 != a1 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 == 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 != 2.3 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 == a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, 2.3 != a2 FROM t6 | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true == c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false == c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, true != c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, false != c FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c == true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c == false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c != true FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT c, c != false FROM t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 == c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, a1 != c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c == a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, c, c != a1 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 == c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, a2 != c FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c == a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, c, c != a2 FROM t6, t8; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT true IN (0.1, 1.2, 2.3, 3.4); @@ -5061,22 +5061,22 @@ SELECT a2 IN (SELECT c FROM t8) FROM t6 LIMIT 1; SELECT true BETWEEN 0.1 and 9.9; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT false BETWEEN 0.1 and 9.9; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a1, a1 BETWEEN 0.1 and 9.9 FROM t6; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... SELECT a2, a2 BETWEEN 0.1 and 9.9 FROM t6; | --- | - null - | - 'Type mismatch: can not convert real to boolean' + | - 'Type mismatch: can not convert double to boolean' | ... -- Check interaction of BOOLEAN and TEXT. @@ -5272,187 +5272,187 @@ SELECT a2, d, d OR a2 FROM t6, t9; SELECT true > 'abc'; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT false > 'abc'; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT true < 'abc'; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT false < 'abc'; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT 'abc' > true; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT 'abc' > false; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT 'abc' < true; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT 'abc' < false; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, true > d FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, false > d FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, true < d FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, false < d FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, d > true FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, d > false FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, d < true FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT d, d < false FROM t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a1, d, a1 > d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a1, d, a1 < d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a1, d, d > a1 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a1, d, d < a1 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a2, d, a2 > d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a2, d, a2 < d FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a2, d, d > a2 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT a2, d, d < a2 FROM t6, t9; | --- | - null - | - 'Type mismatch: can not convert text to boolean' + | - 'Type mismatch: can not convert string to boolean' | ... SELECT true || 'abc'; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT false || 'abc'; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT 'abc' || false; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT 'abc' || true; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, true || d FROM t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, false || d FROM t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, d || false FROM t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, d || true FROM t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, a1 || d FROM t6, t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, a2 || d FROM t6, t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, d || a1 FROM t6, t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... SELECT d, d || a2 FROM t6, t9; | --- | - null - | - 'Inconsistent types: expected text or varbinary got boolean' + | - 'Inconsistent types: expected string or varbinary got boolean' | ... -- diff --git a/test/sql/types.result b/test/sql/types.result index 219559619..a9a5fd536 100644 --- a/test/sql/types.result +++ b/test/sql/types.result @@ -158,39 +158,39 @@ sp:drop() box.execute("SELECT 'abc' || 1;") --- - null -- 'Inconsistent types: expected text or varbinary got unsigned' +- 'Inconsistent types: expected string or varbinary got unsigned' ... box.execute("SELECT 'abc' || 1.123;") --- - null -- 'Inconsistent types: expected text or varbinary got real' +- 'Inconsistent types: expected string or varbinary got double' ... box.execute("SELECT 1 || 'abc';") --- - null -- 'Inconsistent types: expected text or varbinary got unsigned' +- 'Inconsistent types: expected string or varbinary got unsigned' ... box.execute("SELECT 1.123 || 'abc';") --- - null -- 'Inconsistent types: expected text or varbinary got real' +- 'Inconsistent types: expected string or varbinary got double' ... box.execute("SELECt 'a' || 'b' || 1;") --- - null -- 'Inconsistent types: expected text or varbinary got unsigned' +- 'Inconsistent types: expected string or varbinary got unsigned' ... -- What is more, they must be of the same type. -- box.execute("SELECT 'abc' || randomblob(5);") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT randomblob(5) || 'x';") --- - null -- 'Inconsistent types: expected varbinary got text' +- 'Inconsistent types: expected varbinary got string' ... -- Result of BLOBs concatenation must be BLOB. -- @@ -215,17 +215,17 @@ box.execute("INSERT INTO t1 VALUES (randomblob(5));") box.execute("SELECT * FROM t1 WHERE s LIKE 'blob';") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT * FROM t1 WHERE 'blob' LIKE s;") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT * FROM t1 WHERE 'blob' LIKE x'0000';") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT s LIKE NULL FROM t1;") --- @@ -246,12 +246,12 @@ box.execute("INSERT INTO t1 VALUES (1);") box.execute("SELECT * FROM t1 WHERE s LIKE 'int';") --- - null -- 'Inconsistent types: expected text got unsigned' +- 'Inconsistent types: expected string got unsigned' ... box.execute("SELECT * FROM t1 WHERE 'int' LIKE 4;") --- - null -- 'Inconsistent types: expected text got unsigned' +- 'Inconsistent types: expected string got unsigned' ... box.execute("SELECT NULL LIKE s FROM t1;") --- @@ -354,7 +354,7 @@ box.execute("SELECT * FROM tboolean WHERE s1 = 1;") box.execute("SELECT * FROM tboolean WHERE s1 = 1.123;") --- - null -- 'Type mismatch: can not convert real to boolean' +- 'Type mismatch: can not convert double to boolean' ... box.space.TBOOLEAN:drop() --- @@ -1245,12 +1245,12 @@ box.execute("SELECT * FROM t WHERE v = 1") box.execute("SELECT * FROM t WHERE v = 1.123") --- - null -- 'Type mismatch: can not convert real to varbinary' +- 'Type mismatch: can not convert double to varbinary' ... box.execute("SELECT * FROM t WHERE v = 'str'") --- - null -- 'Type mismatch: can not convert text to varbinary' +- 'Type mismatch: can not convert string to varbinary' ... box.execute("SELECT * FROM t WHERE v = x'616263'") --- @@ -1312,12 +1312,12 @@ box.execute("SELECT group_concat(v) FROM t;") box.execute("SELECT lower(v) FROM t;") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT upper(v) FROM t;") --- - null -- 'Inconsistent types: expected text got varbinary' +- 'Inconsistent types: expected string got varbinary' ... box.execute("SELECT abs(v) FROM t;") ---