diff options
author | unknown <bell@sanja.is.com.ua> | 2004-04-07 15:23:05 +0300 |
---|---|---|
committer | unknown <bell@sanja.is.com.ua> | 2004-04-07 15:23:05 +0300 |
commit | 01bcc6ed3c4c1c6515592364b4aec0cae5d2083c (patch) | |
tree | c7d0df7f0334621904d6713b3ea5f4ba1c9cefbe | |
parent | 5650719565806cfa40bb01dad34fc748a46c5c58 (diff) | |
parent | 08797f5918915a235a3b92fa0c05ab68388c7800 (diff) | |
download | mariadb-git-01bcc6ed3c4c1c6515592364b4aec0cae5d2083c.tar.gz |
Merge sanja.is.com.ua:/home/bell/mysql/bk/mysql-4.1
into sanja.is.com.ua:/home/bell/mysql/bk/work-ps3-4.1
mysql-test/r/union.result:
Auto merged
sql/item.cc:
Auto merged
sql/item_sum.cc:
Auto merged
sql/item_sum.h:
Auto merged
sql/log_event.cc:
Auto merged
sql/slave.cc:
Auto merged
sql/sql_base.cc:
Auto merged
sql/sql_cache.cc:
Auto merged
sql/sql_insert.cc:
Auto merged
sql/sql_prepare.cc:
Auto merged
sql/sql_select.cc:
Auto merged
sql/sql_parse.cc:
Auto merged
66 files changed, 8271 insertions, 670 deletions
diff --git a/BitKeeper/etc/logging_ok b/BitKeeper/etc/logging_ok index 4067304c8e1..b3533f2a834 100644 --- a/BitKeeper/etc/logging_ok +++ b/BitKeeper/etc/logging_ok @@ -52,6 +52,7 @@ hf@genie.(none) igor@hundin.mysql.fi igor@rurik.mysql.com ingo@mysql.com +jani@a80-186-24-72.elisa-laajakaista.fi jani@dsl-jkl1657.dial.inet.fi jani@dsl-kpogw4gb5.dial.inet.fi jani@hynda.(none) diff --git a/client/mysql.cc b/client/mysql.cc index 31f563d4116..fe6af909a5a 100644 --- a/client/mysql.cc +++ b/client/mysql.cc @@ -425,8 +425,9 @@ int main(int argc,char *argv[]) } #endif sprintf(buff, "%s", +#ifndef NOT_YET "Type 'help;' or '\\h' for help. Type '\\c' to clear the buffer.\n"); -#ifdef NOT_YET +#else "Type 'help [[%]function name[%]]' to get help on usage of function.\n"); #endif put_info(buff,INFO_INFO); diff --git a/client/mysqltest.c b/client/mysqltest.c index 00165ab4f45..be5dac1c9d9 100644 --- a/client/mysqltest.c +++ b/client/mysqltest.c @@ -2358,7 +2358,7 @@ int run_query(MYSQL* mysql, struct st_query* q, int flags) if (display_metadata) { - dynstr_append(ds,"Catalog\tDatabase\tTable\tTable_alias\tColumn\tColumn_alias\tName\tType\tLength\tMax length\tIs_null\tFlags\tDecimals\n"); + dynstr_append(ds,"Catalog\tDatabase\tTable\tTable_alias\tColumn\tColumn_alias\tName\tType\tLength\tMax length\tIs_null\tFlags\tDecimals\tCharsetnr\n"); for (field= mysql_fetch_fields(res), field_end= field+num_fields ; field < field_end ; field++) @@ -2394,6 +2394,9 @@ int run_query(MYSQL* mysql, struct st_query* q, int flags) dynstr_append_mem(ds, "\t", 1); int10_to_str((int) field->decimals, buff, 10); dynstr_append(ds, buff); + dynstr_append_mem(ds, "\t", 1); + int10_to_str((int) field->charsetnr, buff, 10); + dynstr_append(ds, buff); dynstr_append_mem(ds, "\n", 1); } } diff --git a/include/my_global.h b/include/my_global.h index 4a56741ddbc..e114aefecca 100644 --- a/include/my_global.h +++ b/include/my_global.h @@ -1120,10 +1120,10 @@ typedef union { *((T)+1)=(((A) >> 16));\ *((T)+0)=(((A) >> 24)); } -#define doubleget(V,M) memcpy((byte*) &V,(byte*) (M),sizeof(double)) -#define doublestore(T,V) memcpy((byte*) (T),(byte*) &V,sizeof(double)) -#define longlongget(V,M) memcpy((byte*) &V,(byte*) (M),sizeof(ulonglong)) -#define longlongstore(T,V) memcpy((byte*) (T),(byte*) &V,sizeof(ulonglong)) +#define doubleget(V,M) memcpy_fixed((byte*) &V,(byte*) (M),sizeof(double)) +#define doublestore(T,V) memcpy_fixed((byte*) (T),(byte*) &V,sizeof(double)) +#define longlongget(V,M) memcpy_fixed((byte*) &V,(byte*) (M),sizeof(ulonglong)) +#define longlongstore(T,V) memcpy_fixed((byte*) (T),(byte*) &V,sizeof(ulonglong)) #else diff --git a/include/mysql_com.h b/include/mysql_com.h index 4b94fc71c0c..578ef964d8d 100644 --- a/include/mysql_com.h +++ b/include/mysql_com.h @@ -119,7 +119,7 @@ enum enum_server_command #define CLIENT_SECURE_CONNECTION 32768 /* New 4.1 authentication */ #define CLIENT_MULTI_STATEMENTS 65536 /* Enable/disable multi-stmt support */ #define CLIENT_MULTI_RESULTS 131072 /* Enable/disable multi-results */ -#define CLIENT_REMEMBER_OPTIONS ((ulong) (1L << 31)) +#define CLIENT_REMEMBER_OPTIONS (((ulong) 1) << 31) #define SERVER_STATUS_IN_TRANS 1 /* Transaction has started */ #define SERVER_STATUS_AUTOCOMMIT 2 /* Server in auto_commit mode */ diff --git a/libmysqld/Makefile.am b/libmysqld/Makefile.am index da58a711d22..0cfcf8b1c49 100644 --- a/libmysqld/Makefile.am +++ b/libmysqld/Makefile.am @@ -88,9 +88,9 @@ libmysqld.a: libmysqld_int.a $(INC_LIB) cd tmp ; \ for file in *.a ; do \ bfile=`basename $$file .a` ; \ - ar x $$file; \ + $(AR) x $$file; \ for obj in *.o ; do mv $$obj $${bfile}_$$obj ; done ; \ - ar q ../libmysqld_int2.a *.o ; \ + $(AR) q ../libmysqld_int2.a *.o ; \ rm -f *.o ; \ done mv libmysqld_int2.a libmysqld.a diff --git a/libmysqld/emb_qcache.cc b/libmysqld/emb_qcache.cc index 4dac154ab80..0b6416632b7 100644 --- a/libmysqld/emb_qcache.cc +++ b/libmysqld/emb_qcache.cc @@ -428,7 +428,6 @@ int emb_load_querycache_result(THD *thd, Querycache_stream *src) *prev_row= row; row->data= columns; MYSQL_ROW col_end= columns + mysql->field_count; - uint len; for (; columns < col_end; columns++) src->load_column(&data->alloc, columns); diff --git a/libmysqld/lib_sql.cc b/libmysqld/lib_sql.cc index 6fb23f8f00d..cfb50d3907a 100644 --- a/libmysqld/lib_sql.cc +++ b/libmysqld/lib_sql.cc @@ -332,10 +332,10 @@ char ** copy_arguments_ptr= 0; int init_embedded_server(int argc, char **argv, char **groups) { - char glob_hostname[FN_REFLEN]; - - /* This mess is to allow people to call the init function without - * having to mess with a fake argv */ + /* + This mess is to allow people to call the init function without + having to mess with a fake argv + */ int *argcp; char ***argvp; int fake_argc = 1; diff --git a/myisam/mi_locking.c b/myisam/mi_locking.c index 816748d459a..b13ebfb4cad 100644 --- a/myisam/mi_locking.c +++ b/myisam/mi_locking.c @@ -286,6 +286,21 @@ void mi_copy_status(void* to,void *from) ((MI_INFO*) to)->state= &((MI_INFO*) from)->save_state; } + +/* + Check if should allow concurrent inserts + + IMPLEMENTATION + Don't allow concurrent inserts if we have a hole in the table. + + NOTES + Rtree indexes are disabled in mi_open() + + RETURN + 0 ok to use concurrent inserts + 1 not ok +*/ + my_bool mi_check_status(void* param) { MI_INFO *info=(MI_INFO*) param; diff --git a/myisam/mi_rnext.c b/myisam/mi_rnext.c index e1cf916d6d9..6e6056f98d9 100644 --- a/myisam/mi_rnext.c +++ b/myisam/mi_rnext.c @@ -57,47 +57,45 @@ int mi_rnext(MI_INFO *info, byte *buf, int inx) } else { - switch(info->s->keyinfo[inx].key_alg) - { - case HA_KEY_ALG_RTREE: + switch (info->s->keyinfo[inx].key_alg) { + case HA_KEY_ALG_RTREE: /* - Note that rtree doesn't support that the table - may be changed since last call, so we do need - to skip rows inserted by other threads like in btree + Note that rtree doesn't support that the table + may be changed since last call, so we do need + to skip rows inserted by other threads like in btree */ - error=rtree_get_next(info,inx,info->lastkey_length); - break; + error= rtree_get_next(info,inx,info->lastkey_length); + break; - case HA_KEY_ALG_BTREE: - default: - if (!changed) - { - error=_mi_search_next(info,info->s->keyinfo+inx,info->lastkey, - info->lastkey_length,flag, - info->s->state.key_root[inx]); - } - else - { - error=_mi_search(info,info->s->keyinfo+inx,info->lastkey, - USE_WHOLE_KEY,flag, info->s->state.key_root[inx]); - } - if (!error && info->s->concurrent_insert) - { - while (info->lastpos >= info->state->data_file_length) - { - /* Skip rows that are inserted by other threads since we got a lock */ - if ((error=_mi_search_next(info,info->s->keyinfo+inx,info->lastkey, - info->lastkey_length, - SEARCH_BIGGER, - info->s->state.key_root[inx]))) - break; - } - } + case HA_KEY_ALG_BTREE: + default: + if (!changed) + error= _mi_search_next(info,info->s->keyinfo+inx,info->lastkey, + info->lastkey_length,flag, + info->s->state.key_root[inx]); + else + error= _mi_search(info,info->s->keyinfo+inx,info->lastkey, + USE_WHOLE_KEY,flag, info->s->state.key_root[inx]); } } if (info->s->concurrent_insert) + { + if (!error) + { + while (info->lastpos >= info->state->data_file_length) + { + /* Skip rows inserted by other threads since we got a lock */ + if ((error=_mi_search_next(info,info->s->keyinfo+inx, + info->lastkey, + info->lastkey_length, + SEARCH_BIGGER, + info->s->state.key_root[inx]))) + break; + } + } rw_unlock(&info->s->key_root_lock[inx]); + } /* Don't clear if database-changed */ info->update&= (HA_STATE_CHANGED | HA_STATE_ROW_CHANGED); info->update|= HA_STATE_NEXT_FOUND; diff --git a/myisam/mi_rprev.c b/myisam/mi_rprev.c index 4807e636252..b787210e037 100644 --- a/myisam/mi_rprev.c +++ b/myisam/mi_rprev.c @@ -52,21 +52,22 @@ int mi_rprev(MI_INFO *info, byte *buf, int inx) error=_mi_search(info,share->keyinfo+inx,info->lastkey, USE_WHOLE_KEY, flag, share->state.key_root[inx]); - if (!error) + if (share->concurrent_insert) { - while (info->lastpos >= info->state->data_file_length) + if (!error) { - /* Skip rows that are inserted by other threads since we got a lock */ - if ((error=_mi_search_next(info,share->keyinfo+inx,info->lastkey, - info->lastkey_length, - SEARCH_SMALLER, - share->state.key_root[inx]))) - break; + while (info->lastpos >= info->state->data_file_length) + { + /* Skip rows that are inserted by other threads since we got a lock */ + if ((error=_mi_search_next(info,share->keyinfo+inx,info->lastkey, + info->lastkey_length, + SEARCH_SMALLER, + share->state.key_root[inx]))) + break; + } } - } - - if (share->concurrent_insert) rw_unlock(&share->key_root_lock[inx]); + } info->update&= (HA_STATE_CHANGED | HA_STATE_ROW_CHANGED); info->update|= HA_STATE_PREV_FOUND; if (error) diff --git a/myisam/mi_write.c b/myisam/mi_write.c index 59819b40f96..c17f47fc1ae 100644 --- a/myisam/mi_write.c +++ b/myisam/mi_write.c @@ -917,7 +917,7 @@ int mi_init_bulk_insert(MI_INFO *info, ulong cache_size, ha_rows rows) DBUG_PRINT("enter",("cache_size: %lu", cache_size)); DBUG_ASSERT(!info->bulk_insert && - (!rows || rows >= MI_MIN_ROWS_TO_USE_BULK_INSERT)); + (!rows || rows >= MI_MIN_ROWS_TO_USE_BULK_INSERT)); for (i=total_keylength=num_keys=0 ; i < share->base.keys ; i++) { diff --git a/mysql-test/include/have_debug.inc b/mysql-test/include/have_debug.inc deleted file mode 100644 index 63c0c008b21..00000000000 --- a/mysql-test/include/have_debug.inc +++ /dev/null @@ -1,4 +0,0 @@ --- require r/have_debug.require -disable_query_log; -select instr(version(),convert('debug' using utf8))!=0; -enable_query_log; diff --git a/mysql-test/r/func_gconcat.result b/mysql-test/r/func_gconcat.result index 5807bae6a06..dccd87e3d75 100644 --- a/mysql-test/r/func_gconcat.result +++ b/mysql-test/r/func_gconcat.result @@ -59,11 +59,16 @@ grp group_concat(d order by a desc) 1 a 2 b,a 3 c,d,d,b,b,a -select grp,group_concat(a order by a,d+c) from t1 group by grp; -grp group_concat(a order by a,d+c) +select grp,group_concat(a order by a,d+c-ascii(c)-a) from t1 group by grp; +grp group_concat(a order by a,d+c-ascii(c)-a) 1 1 2 2,3 3 4,5,6,7,8,9 +select grp,group_concat(a order by d+c-ascii(c),a) from t1 group by grp; +grp group_concat(a order by d+c-ascii(c),a) +1 1 +2 3,2 +3 7,8,4,6,9,5 select grp,group_concat(c order by 1) from t1 group by grp; grp group_concat(c order by 1) 1 a @@ -136,17 +141,7 @@ grp ROUND(group_concat(a separator "")) 3 456789 drop table t1; create table t1 (grp int, c char(10)); -insert into t1 values (1,NULL); -insert into t1 values (2,"b"); -insert into t1 values (2,NULL); -insert into t1 values (3,"E"); -insert into t1 values (3,NULL); -insert into t1 values (3,"D"); -insert into t1 values (3,NULL); -insert into t1 values (3,NULL); -insert into t1 values (3,"D"); -insert into t1 values (4,""); -insert into t1 values (5,NULL); +insert into t1 values (1,NULL),(2,"b"),(2,NULL),(3,"E"),(3,NULL),(3,"D"),(3,NULL),(3,NULL),(3,"D"),(4,""),(5,NULL); select grp,group_concat(c order by c) from t1 group by grp; grp group_concat(c order by c) 1 NULL @@ -207,9 +202,21 @@ NULL drop table t1; drop table t2; create table t1 (bar varchar(32)); -insert into t1 values('test'),('test2'); -select * from t1 having group_concat(bar)=''; +insert into t1 values('test1'),('test2'); +select group_concat(bar order by concat(bar,bar)) from t1; +group_concat(bar order by concat(bar,bar)) +test1,test2 +select group_concat(bar order by concat(bar,bar) desc) from t1; +group_concat(bar order by concat(bar,bar) desc) +test2,test1 +select bar from t1 having group_concat(bar)=''; +bar +select bar from t1 having instr(group_concat(bar), "test") > 0; bar +test1 +select bar from t1 having instr(group_concat(bar order by concat(bar,bar) desc), "test2,test1") > 0; +bar +test1 drop table t1; create table t1 (a int, a1 varchar(10)); create table t2 (a0 int); @@ -222,3 +229,75 @@ select group_concat(a1 order by (t1.a)) from t1; group_concat(a1 order by (t1.a)) b,a,c drop table t1, t2; +CREATE TABLE t1 (id1 tinyint(4) NOT NULL, id2 tinyint(4) NOT NULL); +INSERT INTO t1 VALUES (1, 1),(1, 2),(1, 3),(1, 4),(1, 5),(2, 1),(2, 2),(2, 3); +CREATE TABLE t2 (id1 tinyint(4) NOT NULL); +INSERT INTO t2 VALUES (1),(2),(3),(4),(5); +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 AND t1.id1=1 GROUP BY t1.id1; +id1 concat_id +1 1,2,3,4,5 +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 1,2,3,4,5 +2 1,2,3 +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 DESC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 5,4,3,2,1 +2 3,2,1 +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 5,4,3,2,1 +2 3,2,1 +SELECT t1.id1, GROUP_CONCAT(t1.id2,6-t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 51,42,33,24,15 +2 33,24,15 +SELECT t1.id1, GROUP_CONCAT(t1.id2,6-t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 51,42,33,24,15 +2 33,24,15 +SELECT t1.id1, GROUP_CONCAT(t1.id2,"/",6-t1.id2 ORDER BY 1+0,6-t1.id2,t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +id1 concat_id +1 5/1,4/2,3/3,2/4,1/5 +2 3/3,2/4,1/5 +drop table t1,t2; +create table t1 (s1 char(10), s2 int not null); +insert into t1 values ('a',2),('b',2),('c',1),('a',3),('b',4),('c',4); +select distinct s1 from t1 order by s2,s1; +s1 +c +a +b +select group_concat(distinct s1) from t1; +group_concat(distinct s1) +a,b,c +select group_concat(distinct s1 order by s2) from t1 where s2 < 4; +group_concat(distinct s1 order by s2) +c,b,a +select group_concat(distinct s1 order by s2) from t1; +group_concat(distinct s1 order by s2) +c,b,a,c +drop table t1; +create table t1 (a int, c int); +insert into t1 values (1, 2), (2, 3), (2, 4), (3, 5); +create table t2 (a int, c int); +insert into t2 values (1, 5), (2, 4), (3, 3), (3,3); +select group_concat(c) from t1; +group_concat(c) +2,3,4,5 +select group_concat(c order by (select c from t2 where t2.a=t1.a limit 1)) as grp from t1; +grp +5,4,3,2 +select group_concat(c order by (select mid(group_concat(c order by a),1,5) from t2 where t2.a=t1.a)) as grp from t1; +grp +5,4,3,2 +select group_concat(c order by (select mid(group_concat(c order by a),1,5) from t2 where t2.a=t1.a) desc) as grp from t1; +grp +2,4,3,5 +select a,c,(select group_concat(c order by a) from t2 where a=t1.a) as grp from t1 order by grp; +a c grp +3 5 3,3 +2 3 4 +2 4 4 +1 2 5 +drop table t1,t2; diff --git a/mysql-test/r/grant2.result b/mysql-test/r/grant2.result index 0b127188586..d0765e2721f 100644 --- a/mysql-test/r/grant2.result +++ b/mysql-test/r/grant2.result @@ -5,6 +5,9 @@ grant all privileges on `my\_%`.* to mysqltest_1@localhost with grant option; select current_user(); current_user() mysqltest_1@localhost +select current_user; +current_user +mysqltest_1@localhost grant all privileges on `my\_1`.* to mysqltest_2@localhost with grant option; grant all privileges on `my_%`.* to mysqltest_3@localhost with grant option; ERROR 42000: Access denied for user: 'mysqltest_1'@'localhost' to database 'my_%' diff --git a/mysql-test/r/grant_cache.result b/mysql-test/r/grant_cache.result index fc4073d23b1..48068c0f68d 100644 --- a/mysql-test/r/grant_cache.result +++ b/mysql-test/r/grant_cache.result @@ -2,6 +2,12 @@ drop table if exists test.t1,mysqltest.t1,mysqltest.t2; drop database if exists mysqltest; reset query cache; flush status; +show grants for current_user; +Grants for root@localhost +GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION +show grants; +Grants for root@localhost +GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION create database if not exists mysqltest; create table mysqltest.t1 (a int,b int,c int); create table mysqltest.t2 (a int,b int,c int); @@ -41,6 +47,10 @@ grant SELECT on mysqltest.* to mysqltest_1@localhost; grant SELECT on mysqltest.t1 to mysqltest_2@localhost; grant SELECT on test.t1 to mysqltest_2@localhost; grant SELECT(a) on mysqltest.t1 to mysqltest_3@localhost; +show grants for current_user(); +Grants for mysqltest_1@localhost +GRANT USAGE ON *.* TO 'mysqltest_1'@'localhost' +GRANT SELECT ON `mysqltest`.* TO 'mysqltest_1'@'localhost' show status like "Qcache_queries_in_cache"; Variable_name Value Qcache_queries_in_cache 6 @@ -101,6 +111,9 @@ Qcache_hits 3 show status like "Qcache_not_cached"; Variable_name Value Qcache_not_cached 1 +show grants for current_user(); +Grants for @localhost +GRANT USAGE ON *.* TO ''@'localhost' select "user2"; user2 user2 @@ -158,6 +171,10 @@ Qcache_not_cached 7 select "user4"; user4 user4 +show grants; +Grants for mysqltest_1@localhost +GRANT USAGE ON *.* TO 'mysqltest_1'@'localhost' +GRANT SELECT ON `mysqltest`.* TO 'mysqltest_1'@'localhost' select a from t1; ERROR 3D000: No Database Selected select * from mysqltest.t1,test.t1; diff --git a/mysql-test/r/have_debug.require b/mysql-test/r/have_debug.require deleted file mode 100644 index 3ef51a3a6db..00000000000 --- a/mysql-test/r/have_debug.require +++ /dev/null @@ -1,2 +0,0 @@ -instr(version(),convert('debug' using utf8))!=0; -1
\ No newline at end of file diff --git a/mysql-test/r/lowercase_table2.result b/mysql-test/r/lowercase_table2.result index 737d49fc340..c29d52ffffc 100644 --- a/mysql-test/r/lowercase_table2.result +++ b/mysql-test/r/lowercase_table2.result @@ -13,7 +13,7 @@ SHOW CREATE TABLE T1; Table Create Table T1 CREATE TABLE `T1` ( `a` int(11) default NULL -) TYPE=MyISAM +) ENGINE=MyISAM DEFAULT CHARSET=latin1 RENAME TABLE T1 TO T2; SHOW TABLES LIKE "T2"; Tables_in_test (T2) @@ -68,7 +68,7 @@ SHOW CREATE TABLE T1; Table Create Table T1 CREATE TABLE `T1` ( `a` int(11) default NULL -) TYPE=InnoDB +) ENGINE=InnoDB DEFAULT CHARSET=latin RENAME TABLE T1 TO T2; SHOW TABLES LIKE "T2"; Tables_in_test (T2) diff --git a/mysql-test/r/metadata.result b/mysql-test/r/metadata.result index 59914447087..80a01a0ca90 100644 --- a/mysql-test/r/metadata.result +++ b/mysql-test/r/metadata.result @@ -1,36 +1,36 @@ drop table if exists t1,t2; select 1, 1.0, -1, "hello", NULL; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def 1 8 1 1 N 32769 0 -def 1.0 5 3 3 N 32769 1 -def -1 8 1 2 N 32769 0 -def hello 254 5 5 N 1 31 -def NULL 6 0 0 Y 32768 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def 1 8 1 1 N 32769 0 8 +def 1.0 5 3 3 N 32769 1 8 +def -1 8 1 2 N 32769 0 8 +def hello 254 5 5 N 1 31 8 +def NULL 6 0 0 Y 32768 0 8 1 1.0 -1 hello NULL 1 1.0 -1 hello NULL create table t1 (a tinyint, b smallint, c mediumint, d int, e bigint, f float(3,2), g double(4,3), h decimal(5,4), i year, j date, k timestamp, l datetime, m enum('a','b'), n set('a','b'), o char(10)); select * from t1; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def test t1 t1 a a 1 4 0 Y 32768 0 -def test t1 t1 b b 2 6 0 Y 32768 0 -def test t1 t1 c c 9 9 0 Y 32768 0 -def test t1 t1 d d 3 11 0 Y 32768 0 -def test t1 t1 e e 8 20 0 Y 32768 0 -def test t1 t1 f f 4 3 0 Y 32768 2 -def test t1 t1 g g 5 4 0 Y 32768 3 -def test t1 t1 h h 0 7 0 Y 32768 4 -def test t1 t1 i i 13 4 0 Y 32864 0 -def test t1 t1 j j 10 10 0 Y 0 0 -def test t1 t1 k k 7 19 0 N 1089 0 -def test t1 t1 l l 12 19 0 Y 0 0 -def test t1 t1 m m 254 1 0 Y 256 0 -def test t1 t1 n n 254 3 0 Y 2048 0 -def test t1 t1 o o 254 10 0 Y 0 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def test t1 t1 a a 1 4 0 Y 32768 0 63 +def test t1 t1 b b 2 6 0 Y 32768 0 63 +def test t1 t1 c c 9 9 0 Y 32768 0 63 +def test t1 t1 d d 3 11 0 Y 32768 0 63 +def test t1 t1 e e 8 20 0 Y 32768 0 63 +def test t1 t1 f f 4 3 0 Y 32768 2 63 +def test t1 t1 g g 5 4 0 Y 32768 3 63 +def test t1 t1 h h 0 7 0 Y 32768 4 63 +def test t1 t1 i i 13 4 0 Y 32864 0 63 +def test t1 t1 j j 10 10 0 Y 128 0 63 +def test t1 t1 k k 7 19 0 N 1217 0 63 +def test t1 t1 l l 12 19 0 Y 128 0 63 +def test t1 t1 m m 254 1 0 Y 256 0 8 +def test t1 t1 n n 254 3 0 Y 2048 0 8 +def test t1 t1 o o 254 10 0 Y 0 0 8 a b c d e f g h i j k l m n o select a b, b c from t1 as t2; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def test t1 t2 a b 1 4 0 Y 32768 0 -def test t1 t2 b c 2 6 0 Y 32768 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def test t1 t2 a b 1 4 0 Y 32768 0 63 +def test t1 t2 b c 2 6 0 Y 32768 0 63 b c drop table t1; CREATE TABLE t1 (id tinyint(3) default NULL, data varchar(255) default NULL); @@ -38,24 +38,24 @@ INSERT INTO t1 VALUES (1,'male'),(2,'female'); CREATE TABLE t2 (id tinyint(3) unsigned default NULL, data char(3) default '0'); INSERT INTO t2 VALUES (1,'yes'),(2,'no'); select t1.id, t1.data, t2.data from t1, t2 where t1.id = t2.id; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def test t1 t1 id id 1 3 1 Y 32768 0 -def test t1 t1 data data 253 255 6 Y 0 0 -def test t2 t2 data data 254 3 3 Y 0 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def test t1 t1 id id 1 3 1 Y 32768 0 63 +def test t1 t1 data data 253 255 6 Y 0 0 8 +def test t2 t2 data data 254 3 3 Y 0 0 8 id data data 1 male yes 2 female no select t1.id, t1.data, t2.data from t1, t2 where t1.id = t2.id order by t1.id; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def test t1 t1 id id 1 3 1 Y 32768 0 -def test t1 t1 data data 253 255 6 Y 0 0 -def test t2 t2 data data 254 3 3 Y 0 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def test t1 t1 id id 1 3 1 Y 32768 0 63 +def test t1 t1 data data 253 255 6 Y 0 0 8 +def test t2 t2 data data 254 3 3 Y 0 0 8 id data data 1 male yes 2 female no select t1.id from t1 union select t2.id from t2; -Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals -def test t1 t1 id id 1 3 1 Y 32768 0 +Catalog Database Table Table_alias Column Column_alias Name Type Length Max length Is_null Flags Decimals Charsetnr +def test t1 t1 id id 1 3 1 Y 32768 0 63 id 1 2 diff --git a/mysql-test/r/show_check.result b/mysql-test/r/show_check.result index 5a5eb025353..b54d4b5a342 100644 --- a/mysql-test/r/show_check.result +++ b/mysql-test/r/show_check.result @@ -362,3 +362,41 @@ t1 HEAP Fixed 0 5 # # # 5 NULL NULL NULL NULL latin1_swedish_ci NULL t2 HEAP Fixed 0 5 # # # 5 NULL NULL NULL NULL latin1_swedish_ci NULL t3 HEAP Fixed 0 9 # # # 9 NULL NULL NULL NULL latin1_swedish_ci NULL drop table t1, t2, t3; +create database test_$1; +show create database test_$1; +Database Create Database +test_$1 CREATE DATABASE `test_$1` /*!40100 DEFAULT CHARACTER SET latin1 */ +create table test_$1.t1(a int); +insert into test_$1.t1 values(1); +grant select on `test_$1`.* to mysqltest_1@localhost; +grant usage on `test_$1`.* to mysqltest_2@localhost; +grant drop on `test_$1`.* to mysqltest_3@localhost; +select * from t1; +a +1 +show create database test_$1; +Database Create Database +test_$1 CREATE DATABASE `test_$1` /*!40100 DEFAULT CHARACTER SET latin1 */ +drop table t1; +ERROR 42000: Access denied for user: 'mysqltest_1'@'localhost' to database 'test_$1' +drop database test_$1; +ERROR 42000: Access denied for user: 'mysqltest_1'@'localhost' to database 'test_$1' +select * from test_$1.t1; +ERROR 42000: Access denied for user: 'mysqltest_2'@'localhost' to database 'test_$1' +show create database test_$1; +ERROR 42000: Access denied for user: 'mysqltest_2'@'localhost' to database 'test_$1' +drop table test_$1.t1; +ERROR 42000: Access denied for user: 'mysqltest_2'@'localhost' to database 'test_$1' +drop database test_$1; +ERROR 42000: Access denied for user: 'mysqltest_2'@'localhost' to database 'test_$1' +select * from test_$1.t1; +ERROR 42000: Access denied for user: 'mysqltest_3'@'localhost' to database 'test_$1' +show create database test_$1; +ERROR 42000: Access denied for user: 'mysqltest_3'@'localhost' to database 'test_$1' +drop table test_$1.t1; +drop database test_$1; +delete from mysql.user +where user='mysqltest_1' || user='mysqltest_2' || user='mysqltest_3'; +delete from mysql.db +where user='mysqltest_1' || user='mysqltest_2' || user='mysqltest_3'; +flush privileges; diff --git a/mysql-test/r/synchronization.result b/mysql-test/r/synchronization.result index 87800939ed9..ad9443c86da 100644 --- a/mysql-test/r/synchronization.result +++ b/mysql-test/r/synchronization.result @@ -1,23 +1,162 @@ -CREATE TABLE t1 (a int); - CREATE TABLE t2 LIKE t1; -ALTER TABLE t1 add key(a); +CREATE TABLE t1 (x1 int); + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; SHOW CREATE TABLE t2; Table Create Table t2 CREATE TABLE `t2` ( - `a` int(11) default NULL + `xx` int(11) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 -drop table t1, t2; -CREATE TABLE t1 (a int); - CREATE TABLE t2 LIKE t1; -CREATE TABLE t2 (b int); -let's take a look at result of create .. like : ------------ -ERROR HY000: Can't create/write to file './test/t2.frm' (Errcode: 17) ------------ - +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; SHOW CREATE TABLE t2; Table Create Table t2 CREATE TABLE `t2` ( - `b` int(11) default NULL + `xx` int(11) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 -drop table t1, t2; +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x1 x2 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; + ALTER TABLE t1 CHANGE x2 x1 int; +CREATE TABLE t2 LIKE t1; +SHOW CREATE TABLE t2; +Table Create Table +t2 CREATE TABLE `t2` ( + `xx` int(11) default NULL +) ENGINE=MyISAM DEFAULT CHARSET=latin1 +DROP TABLE t2; +DROP TABLE t1; diff --git a/mysql-test/r/union.result b/mysql-test/r/union.result index 91d53ce21d0..fbd4624a57c 100644 --- a/mysql-test/r/union.result +++ b/mysql-test/r/union.result @@ -693,7 +693,7 @@ testc show create table t1; Table Create Table t1 CREATE TABLE `t1` ( - `dt` char(19) default NULL + `dt` binary(19) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1; create table t1 SELECT dt from t2 UNION select sv from t2; @@ -704,7 +704,7 @@ testv show create table t1; Table Create Table t1 CREATE TABLE `t1` ( - `dt` char(19) default NULL + `dt` binary(19) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1; create table t1 SELECT sc from t2 UNION select sv from t2; @@ -726,7 +726,7 @@ tetetetetest show create table t1; Table Create Table t1 CREATE TABLE `t1` ( - `dt` longblob + `dt` blob ) ENGINE=MyISAM DEFAULT CHARSET=latin1 drop table t1; create table t1 SELECT sv from t2 UNION select b from t2; diff --git a/mysql-test/t/func_gconcat.test b/mysql-test/t/func_gconcat.test index d004c81f14e..9d99a57afe5 100644 --- a/mysql-test/t/func_gconcat.test +++ b/mysql-test/t/func_gconcat.test @@ -29,7 +29,8 @@ select grp,group_concat(c order by c) from t1 group by grp; select grp,group_concat(c order by c desc) from t1 group by grp; select grp,group_concat(d order by a) from t1 group by grp; select grp,group_concat(d order by a desc) from t1 group by grp; -select grp,group_concat(a order by a,d+c) from t1 group by grp; +select grp,group_concat(a order by a,d+c-ascii(c)-a) from t1 group by grp; +select grp,group_concat(a order by d+c-ascii(c),a) from t1 group by grp; select grp,group_concat(c order by 1) from t1 group by grp; select grp,group_concat(c order by "c") from t1 group by grp; select grp,group_concat(distinct c order by c) from t1 group by grp; @@ -50,22 +51,12 @@ select grp,group_concat(c order by grp desc) from t1 group by grp order by grp; select grp, group_concat(a separator "")+0 from t1 group by grp;
select grp, group_concat(a separator "")+0.0 from t1 group by grp;
select grp, ROUND(group_concat(a separator "")) from t1 group by grp;
+drop table t1; # Test NULL values -drop table t1; create table t1 (grp int, c char(10)); -insert into t1 values (1,NULL); -insert into t1 values (2,"b"); -insert into t1 values (2,NULL); -insert into t1 values (3,"E"); -insert into t1 values (3,NULL); -insert into t1 values (3,"D"); -insert into t1 values (3,NULL); -insert into t1 values (3,NULL); -insert into t1 values (3,"D"); -insert into t1 values (4,""); -insert into t1 values (5,NULL); +insert into t1 values (1,NULL),(2,"b"),(2,NULL),(3,"E"),(3,NULL),(3,"D"),(3,NULL),(3,NULL),(3,"D"),(4,""),(5,NULL); select grp,group_concat(c order by c) from t1 group by grp; # Test warnings @@ -118,8 +109,12 @@ drop table t2; # check having create table t1 (bar varchar(32)); -insert into t1 values('test'),('test2'); -select * from t1 having group_concat(bar)=''; +insert into t1 values('test1'),('test2'); +select group_concat(bar order by concat(bar,bar)) from t1; +select group_concat(bar order by concat(bar,bar) desc) from t1; +select bar from t1 having group_concat(bar)=''; +select bar from t1 having instr(group_concat(bar), "test") > 0; +select bar from t1 having instr(group_concat(bar order by concat(bar,bar) desc), "test2,test1") > 0; drop table t1; # ORDER BY fix_fields() @@ -129,4 +124,58 @@ insert into t1 values (0,"a"),(0,"b"),(1,"c"); insert into t2 values (1),(2),(3); select group_concat(a1 order by (t1.a IN (select a0 from t2))) from t1; select group_concat(a1 order by (t1.a)) from t1; -drop table t1, t2;
\ No newline at end of file +drop table t1, t2; + +# +# Problem with GROUP BY (Bug #2695) +# + +CREATE TABLE t1 (id1 tinyint(4) NOT NULL, id2 tinyint(4) NOT NULL); +INSERT INTO t1 VALUES (1, 1),(1, 2),(1, 3),(1, 4),(1, 5),(2, 1),(2, 2),(2, 3); +CREATE TABLE t2 (id1 tinyint(4) NOT NULL); +INSERT INTO t2 VALUES (1),(2),(3),(4),(5); +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 AND t1.id1=1 GROUP BY t1.id1; +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY t1.id2 DESC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +SELECT t1.id1, GROUP_CONCAT(t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; + +# The following failed when it was run twice: +SELECT t1.id1, GROUP_CONCAT(t1.id2,6-t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +SELECT t1.id1, GROUP_CONCAT(t1.id2,6-t1.id2 ORDER BY 6-t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; + +SELECT t1.id1, GROUP_CONCAT(t1.id2,"/",6-t1.id2 ORDER BY 1+0,6-t1.id2,t1.id2 ASC) AS concat_id FROM t1, t2 WHERE t1.id1 = t2.id1 GROUP BY t1.id1; +drop table t1,t2; + +# +# Problem with distinct (Bug #3381) +# + +create table t1 (s1 char(10), s2 int not null); +insert into t1 values ('a',2),('b',2),('c',1),('a',3),('b',4),('c',4); +select distinct s1 from t1 order by s2,s1; +select group_concat(distinct s1) from t1; +select group_concat(distinct s1 order by s2) from t1 where s2 < 4; +# The following is wrong and needs to be fixed ASAP +select group_concat(distinct s1 order by s2) from t1; +drop table t1; + +# +# Test with subqueries (Bug #3319) +# + +create table t1 (a int, c int); +insert into t1 values (1, 2), (2, 3), (2, 4), (3, 5); +create table t2 (a int, c int); +insert into t2 values (1, 5), (2, 4), (3, 3), (3,3); +select group_concat(c) from t1; +select group_concat(c order by (select c from t2 where t2.a=t1.a limit 1)) as grp from t1; + +select group_concat(c order by (select mid(group_concat(c order by a),1,5) from t2 where t2.a=t1.a)) as grp from t1; +select group_concat(c order by (select mid(group_concat(c order by a),1,5) from t2 where t2.a=t1.a) desc) as grp from t1; + +# The following returns random results as we are sorting on blob addresses +# select group_concat(c order by (select group_concat(c order by a) from t2 where t2.a=t1.a)) as grp from t1; +# select group_concat(c order by (select group_concat(c) from t2 where a=t1.a)) as grp from t1; + +select a,c,(select group_concat(c order by a) from t2 where a=t1.a) as grp from t1 order by grp; +drop table t1,t2; diff --git a/mysql-test/t/func_group.test b/mysql-test/t/func_group.test index ce89cbe1b22..2bd4838f934 100644 --- a/mysql-test/t/func_group.test +++ b/mysql-test/t/func_group.test @@ -134,7 +134,6 @@ select max(t2.a1) from t1 left outer join t2 on t1.a2=t2.a1 and 1=0 where t2.a1= select max(t1.a2),max(t2.a1) from t1 left outer join t2 on t1.a1=10; drop table t1,t2; - # # Tests to check MIN/MAX query optimization # diff --git a/mysql-test/t/grant2.test b/mysql-test/t/grant2.test index 148c4d3da21..1fc1ed78385 100644 --- a/mysql-test/t/grant2.test +++ b/mysql-test/t/grant2.test @@ -15,6 +15,7 @@ grant all privileges on `my\_%`.* to mysqltest_1@localhost with grant option; connect (user1,localhost,mysqltest_1,,); connection user1; select current_user(); +select current_user; grant all privileges on `my\_1`.* to mysqltest_2@localhost with grant option; --error 1044 grant all privileges on `my_%`.* to mysqltest_3@localhost with grant option; diff --git a/mysql-test/t/grant_cache.test b/mysql-test/t/grant_cache.test index 5ebf621ff40..7806253124e 100644 --- a/mysql-test/t/grant_cache.test +++ b/mysql-test/t/grant_cache.test @@ -12,6 +12,8 @@ reset query cache; flush status; connect (root,localhost,root,,test,$MASTER_MYPORT,master.sock); connection root; +show grants for current_user; +show grants; --disable_warnings create database if not exists mysqltest; --enable_warnings @@ -43,6 +45,7 @@ grant SELECT(a) on mysqltest.t1 to mysqltest_3@localhost; # The following queries should be fetched from cache connect (user1,localhost,mysqltest_1,,mysqltest,$MASTER_MYPORT,master.sock); connection user1; +show grants for current_user(); show status like "Qcache_queries_in_cache"; show status like "Qcache_hits"; show status like "Qcache_not_cached"; @@ -64,6 +67,10 @@ show status like "Qcache_queries_in_cache"; show status like "Qcache_hits"; show status like "Qcache_not_cached"; +connect (unkuser,localhost,,,,$MASTER_MYPORT,master.sock); +connection unkuser; +show grants for current_user(); + # The following queries should be fetched from cache connect (user2,localhost,mysqltest_2,,mysqltest,$MASTER_MYPORT,master.sock); connection user2; @@ -104,6 +111,7 @@ show status like "Qcache_not_cached"; connect (user4,localhost,mysqltest_1,,*NO-ONE*,$MASTER_MYPORT,master.sock); connection user4; select "user4"; +show grants; --error 1046 select a from t1; # The following query is not cached before (different database) diff --git a/mysql-test/t/show_check.test b/mysql-test/t/show_check.test index 638626a7456..b0307af19bb 100644 --- a/mysql-test/t/show_check.test +++ b/mysql-test/t/show_check.test @@ -256,3 +256,51 @@ delete from t3 where a=5; show table status; drop table t1, t2, t3; + +# +# Test for bug #3342 SHOW CREATE DATABASE seems to require DROP privilege +# + +create database test_$1; +show create database test_$1; +create table test_$1.t1(a int); +insert into test_$1.t1 values(1); +grant select on `test_$1`.* to mysqltest_1@localhost; +grant usage on `test_$1`.* to mysqltest_2@localhost; +grant drop on `test_$1`.* to mysqltest_3@localhost; + +connect (con1,localhost,mysqltest_1,,test_$1); +connection con1; +select * from t1; +show create database test_$1; +--error 1044 +drop table t1; +--error 1044 +drop database test_$1; + +connect (con2,localhost,mysqltest_2,,test); +connection con2; +--error 1044 +select * from test_$1.t1; +--error 1044 +show create database test_$1; +--error 1044 +drop table test_$1.t1; +--error 1044 +drop database test_$1; + +connect (con3,localhost,mysqltest_3,,test); +connection con3; +--error 1044 +select * from test_$1.t1; +--error 1044 +show create database test_$1; +drop table test_$1.t1; +drop database test_$1; + +connection default; +delete from mysql.user +where user='mysqltest_1' || user='mysqltest_2' || user='mysqltest_3'; +delete from mysql.db +where user='mysqltest_1' || user='mysqltest_2' || user='mysqltest_3'; +flush privileges; diff --git a/mysql-test/t/synchronization-master.opt b/mysql-test/t/synchronization-master.opt deleted file mode 100644 index 710a0395d55..00000000000 --- a/mysql-test/t/synchronization-master.opt +++ /dev/null @@ -1 +0,0 @@ ---exit-info=2048
\ No newline at end of file diff --git a/mysql-test/t/synchronization.test b/mysql-test/t/synchronization.test index 695e405544a..7bdeaa8a740 100644 --- a/mysql-test/t/synchronization.test +++ b/mysql-test/t/synchronization.test @@ -1,45 +1,33 @@ --- source include/have_crypt.inc - # # Test for Bug #2385 CREATE TABLE LIKE lacks locking on source and destination table # -connect (con_to_sleep,localhost,lock_controller,,); -connect (con_to_harm_sleeper,localhost,root,,); +connect (con1,localhost,root,,); +connect (con2,localhost,root,,); # locking of source: -connection con_to_sleep; -CREATE TABLE t1 (a int); -send CREATE TABLE t2 LIKE t1; - -connection con_to_harm_sleeper; -sleep 1; -ALTER TABLE t1 add key(a); - -connection con_to_sleep; -sleep 4; -SHOW CREATE TABLE t2; -drop table t1, t2; - -# locking of destination: -connection con_to_sleep; -CREATE TABLE t1 (a int); -send CREATE TABLE t2 LIKE t1; - -connection con_to_harm_sleeper; -sleep 1; -CREATE TABLE t2 (b int); -disable_query_log; -select "-----------" as "let's take a look at result of create .. like : "; -enable_query_log; - -connection con_to_sleep; -sleep 1; ---error 1 -reap; -disable_query_log; -select "" as "-----------"; -enable_query_log; -SHOW CREATE TABLE t2; -drop table t1, t2;
\ No newline at end of file +CREATE TABLE t1 (x1 int); +let $1= 10; +while ($1) +{ + connection con1; + send ALTER TABLE t1 CHANGE x1 x2 int; + connection con2; + CREATE TABLE t2 LIKE t1; + replace_result x1 xx x2 xx; + SHOW CREATE TABLE t2; + DROP TABLE t2; + connection con1; + reap; + send ALTER TABLE t1 CHANGE x2 x1 int; + connection con2; + CREATE TABLE t2 LIKE t1; + replace_result x1 xx x2 xx; + SHOW CREATE TABLE t2; + DROP TABLE t2; + connection con1; + reap; + dec $1; +} +DROP TABLE t1; diff --git a/scripts/mysqld_multi.sh b/scripts/mysqld_multi.sh index 3165a01362c..a4f2b18fda8 100644 --- a/scripts/mysqld_multi.sh +++ b/scripts/mysqld_multi.sh @@ -4,12 +4,12 @@ use Getopt::Long; use POSIX qw(strftime); $|=1; -$VER="2.5"; +$VER="2.6"; $opt_config_file = undef(); $opt_example = 0; $opt_help = 0; -$opt_log = "/tmp/mysqld_multi.log"; +$opt_log = ""; $opt_mysqladmin = "@bindir@/mysqladmin"; $opt_mysqld = "@libexecdir@/mysqld"; $opt_no_log = 0; @@ -18,6 +18,9 @@ $opt_tcp_ip = 0; $opt_user = "root"; $opt_version = 0; +my $my_print_defaults_exists= 1; +my $logdir= undef(); + my ($mysqld, $mysqladmin, $groupids, $homedir, $my_progname); $homedir = $ENV{HOME}; @@ -42,7 +45,9 @@ sub main print "Please make sure you have this command available and\n"; print "in your path. The command is available from the latest\n"; print "MySQL distribution.\n"; + $my_print_defaults_exists= 0; } + init_log(); my @defops = `my_print_defaults mysqld_multi`; chop @defops; splice @ARGV, 0, 0, @defops; @@ -113,6 +118,56 @@ sub main } #### +#### Init log file. Check for appropriate place for log file, in the following +#### order my_print_defaults mysqld datadir, @datadir@, /var/log, /tmp +#### + +sub init_log +{ + if ($my_print_defaults_exists) + { + @mysqld_opts= `my_print_defaults mysqld`; + chomp @mysqld_opts; + foreach my $opt (@mysqld_opts) + { + if ($opt =~ m/^\-\-datadir[=](.*)/) + { + if (-d "$1" && -w "$1") + { + $logdir= $1; + } + } + } + } + if (!defined($logdir)) + { + $logdir= "@datadir@" if (-d "@datadir@" && -w "@datadir@"); + } + if (!defined($logdir)) + { + $logdir= "/var/log" if (-d "/var/log" && -w "/var/log"); + } + if (!defined($logdir)) + { + if (-d "/tmp" && -w "/tmp" && ! -e "/tmp/mysqld_multi.log") + { + $logdir= "/tmp"; + } + } + if (!defined($logdir)) + { + # We still couldn't get a default log file in place. Log file + # will be disabled unless user sets it with an option + + $opt_no_log= 1; + } + else + { + $opt_log= "$logdir/mysqld_multi.log"; + } +} + +#### #### Report living and not running MySQL servers #### diff --git a/sql-bench/limits/mysql-4.0.cfg b/sql-bench/limits/mysql-4.0.cfg new file mode 100644 index 00000000000..feaa79e43e9 --- /dev/null +++ b/sql-bench/limits/mysql-4.0.cfg @@ -0,0 +1,7050 @@ +#This file is automaticly generated by crash-me 1.61 + +NEG=yes # update of column= -column + ###< create table crash_q (a integer) + ###> OK + ###< insert into crash_q values(10) + ###> OK + ###< update crash_q set a=-a + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +Need_cast_for_null=no # Need to cast NULL for arithmetic + ### Check if numeric_null (NULL) is 'NULL' +alter_add_col=yes # Alter table add column + ###< alter table crash_q add d integer + ###> OK + ### + ###As far as all queries returned OK, result is YES +alter_add_constraint=yes # Alter table add constraint + ###< alter table crash_q add constraint c2 check(a > b) + ###> OK + ### + ###As far as all queries returned OK, result is YES +alter_add_foreign_key=no # Alter table add foreign key + ###< alter table crash_q add constraint f1 foreign key(c1) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1 + ###< references crash_q1(c1) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'references crash_q1(c1)' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +alter_add_multi_col=yes # Alter table add many columns + ###< alter table crash_q add (f integer,g integer) + ###> OK +alter_add_primary_key=with constraint # Alter table add primary key + ###< alter table crash_q1 add constraint p1 primary key(c1) + ###> OK +alter_add_unique=yes # Alter table add unique + ###< alter table crash_q add constraint u1 unique(c1) + ###> OK + ### + ###As far as all queries returned OK, result is YES +alter_alter_col=yes # Alter table alter column default + ###< alter table crash_q alter b set default 10 + ###> OK + ### + ###As far as all queries returned OK, result is YES +alter_change_col=yes # Alter table change column + ###< alter table crash_q change a e char(50) + ###> OK + ### + ###As far as all queries returned OK, result is YES +alter_drop_col=yes # Alter table drop column + ###< alter table crash_q drop column b + ###> OK +alter_drop_constraint=no # Alter table drop constraint + ###< alter table crash_q drop constraint c2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint c2' at line 1 + ### + ###< alter table crash_q drop constraint c2 restrict + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint c2 restrict' at line 1 +alter_drop_foreign_key=with drop foreign key # Alter table drop foreign key + ###< alter table crash_q drop constraint f1 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint f1' at line 1 + ### + ###< alter table crash_q drop constraint f1 restrict + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint f1 restrict' at line 1 + ### + ###< alter table crash_q drop foreign key f1 + ###> OK +alter_drop_primary_key=drop primary key # Alter table drop primary key + ###< alter table crash_q1 drop constraint p1 restrict + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint p1 restrict' at line 1 + ### + ###< alter table crash_q1 drop primary key + ###> OK +alter_drop_unique=with drop key # Alter table drop unique + ###< alter table crash_q drop constraint u1 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint u1' at line 1 + ### + ###< alter table crash_q drop constraint u1 restrict + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint u1 restrict' at line 1 + ### + ###< alter table crash_q drop key c1 + ###> OK +alter_modify_col=yes # Alter table modify column + ###< alter table crash_q modify c1 CHAR(20) + ###> OK +alter_rename_table=yes # Alter table rename table + ###< alter table crash_q rename to crash_q1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +atomic_updates=no # atomic updates + ###< create table crash_q (a integer not null,primary key (a)) + ###> OK + ###< insert into crash_q values (2) + ###> OK + ###< insert into crash_q values (3) + ###> OK + ###< insert into crash_q values (1) + ###> OK + ###< update crash_q set a=a+1 + ###> execute error:Duplicate entry '3' for key 1 + ###< drop table crash_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +automatic_rowid=_rowid # Automatic row id + ###< create table crash_q (a int not null, primary key(a)) + ###> OK + ###< insert into crash_q values (1) + ###> OK + ###< select _rowid from crash_q + ###> OK + ###< drop table crash_q + ###> OK +binary_numbers=no # binary numbers (0b1001) + ###< select 0b1001 + ###> execute error:Unknown column '0b1001' in 'field list' + ### + ###As far as some queries didnt return OK, result is NO +binary_strings=no # binary strings (b'0110') + ###< select b'0110' + ###> execute error:Unknown column 'b' in 'field list' + ### + ###As far as some queries didnt return OK, result is NO +case_insensitive_strings=yes # Case insensitive compare + ### + ###<select b from crash_me where b = 'A' + ###>a +char_is_space_filled=no # char are space filled + ### + ###<select concat(b,b) from crash_me where b = 'a ' + ###>aa + ###We expected 'a a ' but got 'aa' +column_alias=yes # Column alias + ###< select a as ab from crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +columns_in_group_by=+64 # number of columns in group by + ###We are trying (example with N=5): + ###create table crash_q (q1 integer,q2 integer,q3 integer,q4 integer,q5 integer) + ###insert into crash_q values(1,1,1,1,1) + ###insert into crash_q values(1,1,1,1,1) + ###select q1,q2,q3,q4,q5 from crash_q group by q1,q2,q3,q4,q5 +columns_in_order_by=+64 # number of columns in order by + ###We are trying (example with N=5): + ###create table crash_q (q1 integer,q2 integer,q3 integer,q4 integer,q5 integer) + ###insert into crash_q values(1,1,1,1,1) + ###insert into crash_q values(1,1,1,1,1) + ###select * from crash_q order by q1,q2,q3,q4,q5 +comment_#=yes # # as comment + ###< select * from crash_me # Testing of comments + ###> OK + ### + ###As far as all queries returned OK, result is YES +comment_--=yes # -- as comment (ANSI) + ###< select * from crash_me -- Testing of comments + ###> OK + ### + ###As far as all queries returned OK, result is YES +comment_/**/=yes # /* */ as comment + ###< select * from crash_me /* Testing of comments */ + ###> OK + ### + ###As far as all queries returned OK, result is YES +comment_//=no # // as comment + ###< select * from crash_me // Testing of comments + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '// Testing of comments' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +compute=no # Compute + ###< select a from crash_me order by a compute sum(a) by a + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'compute sum(a) by a' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +connections=101 # Simultaneous connections (installation default) +constraint_check=syntax only # Column constraints + ###< create table crash_q (a int check (a>0)) + ###> OK + ### + ###< insert into crash_q values(0) + ###> OK + ### + ###< drop table crash_q + ###> OK +constraint_check_named=syntax only # Named constraints + ###< create table crash_q (a int ,b int, constraint abc check (a>b)) + ###> OK + ### + ###< insert into crash_q values(0,0) + ###> OK + ### + ###< drop table crash_q + ###> OK +constraint_check_table=syntax only # Table constraints + ###< create table crash_q (a int ,b int, check (a>b)) + ###> OK + ### + ###< insert into crash_q values(0,0) + ###> OK + ### + ###< drop table crash_q + ###> OK +constraint_null=yes # NULL constraint (SyBase style) + ###< create table crash_q (a int null) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +crash_me_safe=yes # crash me safe +crash_me_version=1.61 # crash me version +create_default=yes # default value for column + ###< create table crash_q (q integer default 10 not null) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +create_default_func=no # default value function for column + ###< create table crash_q (q integer not null,q1 integer default (1+1)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1+1))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +create_if_not_exists=yes # create table if not exists + ###< create table crash_q (q integer) + ###> OK + ###< create table if not exists crash_q (q integer) + ###> OK + ### + ###As far as all queries returned OK, result is YES +create_index=yes # create index + ###< create index crash_q on crash_me (a) + ###> OK +create_schema=no # Create SCHEMA + ###< create schema crash_schema create table crash_q (a int) create table crash_q2(b int) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'schema crash_schema create table crash_q (a int) create table c + ###< drop schema crash_schema cascade + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'schema crash_schema cascade' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +create_table_select=yes # create table from select + ###< create table crash_q SELECT * from crash_me + ###> OK +cross_join=yes # cross join (same as from a,b) + ###< select crash_me.a from crash_me cross join crash_me3 + ###> OK + ### + ###As far as all queries returned OK, result is YES +date_as_string=yes # String functions on date columns + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('1998-03-03') + ###> OK + ### + ###<select left(a,4) from crash_me2 + ###>1998 + ### + ###< drop table crash_me2 + ###> OK +date_format_EUR=error # Supports DD.MM.YYYY (EUR) format + ###< insert into crash_me_d(a) values ('16.08.1963') + ###> OK + ### + ###<select a from crash_me_d + ###>0000-00-00 + ###We expected '1963-08-16' but got '0000-00-00' + ### + ###< delete from crash_me_d + ###> OK +date_format_EUR_with_date=error # Supports DATE 'DD.MM.YYYY' (EUR) format + ###< insert into crash_me_d(a) values (DATE '16.08.1963') + ###> OK + ### + ###<select a from crash_me_d + ###>0000-00-00 + ###We expected '1963-08-16' but got '0000-00-00' + ### + ###< delete from crash_me_d + ###> OK +date_format_ISO=yes # Supports YYYY-MM-DD (ISO) format + ###< insert into crash_me_d(a) values ('1963-08-16') + ###> OK + ### + ###<select a from crash_me_d + ###>1963-08-16 + ### + ###< delete from crash_me_d + ###> OK +date_format_ISO_with_date=yes # Supports DATE 'YYYY-MM-DD' (ISO) format + ###< insert into crash_me_d(a) values (DATE '1963-08-16') + ###> OK + ### + ###<select a from crash_me_d + ###>1963-08-16 + ### + ###< delete from crash_me_d + ###> OK +date_format_USA=error # Supports MM/DD/YYYY format + ###< insert into crash_me_d(a) values ('08/16/1963') + ###> OK + ### + ###<select a from crash_me_d + ###>0000-00-00 + ###We expected '1963-08-16' but got '0000-00-00' + ### + ###< delete from crash_me_d + ###> OK +date_format_USA_with_date=error # Supports DATE 'MM/DD/YYYY' format + ###< insert into crash_me_d(a) values (DATE '08/16/1963') + ###> OK + ### + ###<select a from crash_me_d + ###>0000-00-00 + ###We expected '1963-08-16' but got '0000-00-00' + ### + ###< delete from crash_me_d + ###> OK +date_format_YYYYMMDD=yes # Supports YYYYMMDD format + ###< insert into crash_me_d(a) values ('19630816') + ###> OK + ### + ###<select a from crash_me_d + ###>1963-08-16 + ### + ###< delete from crash_me_d + ###> OK +date_format_YYYYMMDD_with_date=yes # Supports DATE 'YYYYMMDD' format + ###< insert into crash_me_d(a) values (DATE '19630816') + ###> OK + ### + ###<select a from crash_me_d + ###>1963-08-16 + ### + ###< delete from crash_me_d + ###> OK +date_format_inresult=iso # Date format in result + ###< insert into crash_me_d values( sysdate() ) + ###> OK + ### + ###< select a from crash_me_d + ###> 2003-08-27 + ###< delete from crash_me_d + ###> OK +date_infinity=error # Supports 'infinity dates + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('infinity') + ###> OK + ### + ###<select a from crash_me2 + ###>0000-00-00 + ###We expected 'infinity' but got '0000-00-00' + ### + ###< drop table crash_me2 + ###> OK +date_last=yes # Supports 9999-12-31 dates + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('9999-12-31') + ###> OK + ### + ###<select a from crash_me2 + ###>9999-12-31 + ### + ###< drop table crash_me2 + ###> OK +date_one=yes # Supports 0001-01-01 dates + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('0001-01-01') + ###> OK + ### + ###<select a from crash_me2 + ###>0001-01-01 + ### + ###< drop table crash_me2 + ###> OK +date_with_YY=yes # Supports YY-MM-DD 2000 compilant dates + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('98-03-03') + ###> OK + ### + ###<select a from crash_me2 + ###>1998-03-03 + ### + ###< drop table crash_me2 + ###> OK + ### + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('10-03-03') + ###> OK + ### + ###<select a from crash_me2 + ###>2010-03-03 + ### + ###< drop table crash_me2 + ###> OK +date_zero=yes # Supports 0000-00-00 dates + ###< create table crash_me2 (a date not null) + ###> OK + ###< insert into crash_me2 values ('0000-00-00') + ###> OK + ### + ###<select a from crash_me2 + ###>0000-00-00 + ### + ###< drop table crash_me2 + ###> OK +domains=no # Domains (ANSI SQL) + ###< create domain crash_d as varchar(10) default 'Empty' check (value <> 'abcd') + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'domain crash_d as varchar(10) default 'Empty' check (value <> ' + ###< create table crash_q(a crash_d, b int) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'crash_d, b int)' at line 1 + ###< insert into crash_q(a,b) values('xyz',10) + ###> execute error:Table 'test.crash_q' doesn't exist + ###< insert into crash_q(b) values(10) + ###> execute error:Table 'test.crash_q' doesn't exist + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ###< drop domain crash_d + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'domain crash_d' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +dont_require_cast_to_float=yes # No need to cast from integer to float + ###< select exp(1) + ###> OK + ### + ###As far as all queries returned OK, result is YES +double_quotes=yes # Double '' as ' in strings + ### + ###<select 'Walker''s' + ###>Walker's +drop_if_exists=yes # drop table if exists + ###< create table crash_q (q integer) + ###> OK + ###< drop table if exists crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +drop_index=with 'ON' # drop index + ###< drop index crash_q + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '' at line 1 + ### + ###< drop index crash_q from crash_me + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'from crash_me' at line 1 + ### + ###< drop index crash_q on crash_me + ###> OK +drop_requires_cascade=no # drop table require cascade/restrict + ###< create table crash_me (a integer not null) + ###> OK + ###< drop table crash_me + ###> OK +drop_restrict=yes # drop table with cascade/restrict + ###< create table crash_q (a int) + ###> OK + ###< drop table crash_q restrict + ###> OK + ### + ###As far as all queries returned OK, result is YES +end_colon=yes # allows end ';' + ###< select * from crash_me; + ###> OK + ### + ###As far as all queries returned OK, result is YES +except=no # except + ###< select * from crash_me except select * from crash_me3 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me3' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +except_all=no # except all + ###< select * from crash_me except all select * from crash_me3 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all select * from crash_me3' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +except_all_incompat=no # except all (incompatible lists) + ###< select * from crash_me except all select * from crash_me2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all select * from crash_me2' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +except_incompat=no # except (incompatible lists) + ###< select * from crash_me except select * from crash_me2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me2' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +field_name_case=yes # case independent field names + ###< create table crash_q (q integer) + ###> OK + ###< insert into crash_q(Q) values (1) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +float_int_expr=yes # mixing of integer and float in expression + ###< select 1+1.0 + ###> OK + ### + ###As far as all queries returned OK, result is YES +foreign_key=syntax only # foreign keys + ###< create table crash_me_qf (a integer not null,primary key (a)) + ###> OK + ### + ###< create table crash_me_qf2 (a integer not null,foreign key (a) references crash_me_qf (a)) + ###> OK + ### + ###< insert into crash_me_qf values (1) + ###> OK + ### + ###< insert into crash_me_qf2 values (2) + ###> OK + ### + ###< drop table crash_me_qf2 + ###> OK + ### + ###< drop table crash_me_qf + ###> OK +full_outer_join=no # full outer join + ###< select crash_me.a from crash_me full join crash_me2 ON + ### crash_me.a=crash_me2.a + ###> execute error:Unknown table 'crash_me' in field list + ### + ###As far as some queries didnt return OK, result is NO +func_extra_!=yes # Function NOT as '!' in SELECT + ### + ###<select ! 1 + ###>0 +func_extra_%=yes # Function MOD as % + ### + ###<select 10%7 + ###>3 +func_extra_&=yes # Function & (bitwise and) + ### + ###<select 5 & 3 + ###>1 +func_extra_&&=yes # Function AND as '&&' + ### + ###<select 1=1 && 2=2 + ###>1 +func_extra_<>=yes # Function <> in SELECT + ### + ###<select 1<>1 + ###>0 +func_extra_==yes # Function = + ### + ###<select (1=1) + ###>1 +func_extra_add_months=no # Function ADD_MONTHS + ### + ###<select add_months('1997-01-01',1) from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1997-01-01',1) from crash_me_d' at line 1 +func_extra_adddate=no # Function ADDDATE + ### + ###<select ADDDATE('2002-12-01',3) from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '3) from crash_me_d' at line 1 +func_extra_addtime=no # Function ADDTIME + ### + ###<select ADDTIME('20:02:12','00:00:03') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:12','00:00:03')' at line 1 +func_extra_alpha=no # Function ALPHA + ### + ###<select alpha('Aâ',2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('Aâ',2)' at line 1 +func_extra_and_or=yes # Function AND and OR in SELECT + ### + ###<select 1=1 AND 2=2 + ###>1 +func_extra_ascii_char=no # Function ASCII_CHAR + ### + ###<select ASCII_CHAR(65) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(65)' at line 1 +func_extra_ascii_code=no # Function ASCII_CODE + ### + ###<select ASCII_CODE('A') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('A')' at line 1 +func_extra_ascii_string=error # Function ASCII in string cast + ### + ###<select ascii('a') + ###>97 + ###We expected 'a' but got '97' +func_extra_atn2=no # Function ATN2 + ### + ###<select atn2(1,0) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1,0)' at line 1 +func_extra_auto_num2string=yes # Function automatic num->string convert + ### + ###<select concat('a',2) + ###>a2 +func_extra_auto_string2num=yes # Function automatic string->num convert + ### + ###<select '1'+2 + ###>3 +func_extra_between=yes # Function BETWEEN in SELECT + ### + ###<select 5 between 4 and 6 + ###>1 +func_extra_binary_shifts=yes # Function << and >> (bitwise shifts) + ### + ###<select (1 << 4) >> 2 + ###>4 +func_extra_bit_count=yes # Function BIT_COUNT + ### + ###<select bit_count(5) + ###>2 +func_extra_ceil=yes # Function CEIL + ### + ###<select ceil(-4.5) + ###>-4 +func_extra_char_date=no # Function CHAR (conversation date) + ### + ###<select CHAR(a,EUR) from crash_me_d + ###> execute failed:Unknown column 'EUR' in 'field list' +func_extra_charindex=no # Function CHARINDEX + ### + ###<select charindex('a','crash') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('a','crash')' at line 1 +func_extra_chr=no # Function CHR + ### + ###<select CHR(65) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(65)' at line 1 +func_extra_chr_str=no # Function CHR (any type to string) + ### + ###<select CHR(67) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(67)' at line 1 +func_extra_concat_as_+=error # Function concatenation with + + ### + ###<select 'abc' + 'def' + ###>0 + ###We expected 'abcdef' but got '0' +func_extra_concat_list=yes # Function CONCAT(list) + ### + ###<select concat('a','b','c','d') + ###>abcd +func_extra_convert=no # Function CONVERT + ### + ###<select convert(CHAR,5) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '5)' at line 1 +func_extra_cosh=no # Function COSH + ### + ###<select cosh(0) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(0)' at line 1 +func_extra_date=no # Function DATE + ### + ###<select date('1963-08-16') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1963-08-16') from crash_me_d' at line 1 +func_extra_date_format=yes # Function DATE_FORMAT + ### + ###<select date_format('1997-01-02 03:04:05','M W D Y y m d h i s w') from crash_me_d + ###>M W D Y y m d h i s w +func_extra_dateadd=no # Function DATEADD + ### + ###<select dateadd(day,3,'1997-11-30') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(day,3,'1997-11-30') from crash_me_d' at line 1 +func_extra_datediff=no # Function DATEDIFF + ### + ###<select datediff(month,'Oct 21 1997','Nov 30 1997') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(month,'Oct 21 1997','Nov 30 1997') from crash_me_d' at line 1 +func_extra_datediff2arg=no # Function DATEDIFF (2 arg) + ### + ###<select DATEDIFF('2002-12-04','2002-12-01') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('2002-12-04','2002-12-01') from crash_me_d' at line 1 +func_extra_datename=no # Function DATENAME + ### + ###<select datename(month,'Nov 30 1997') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(month,'Nov 30 1997') from crash_me_d' at line 1 +func_extra_datepart=no # Function DATEPART + ### + ###<select datepart(month,'July 20 1997') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(month,'July 20 1997') from crash_me_d' at line 1 +func_extra_day=no # Function DAY + ### + ###<select DAY('2002-12-01') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('2002-12-01') from crash_me_d' at line 1 +func_extra_decode=no # Function DECODE + ### + ###<select DECODE('S-103','T72',1,'S-103',2,'Leopard',3) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '1,'S-103',2,'Leopard',3)' at line 1 +func_extra_ebcdic_string=no # Function EBCDIC in string cast + ### + ###<select ebcdic('a') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('a')' at line 1 +func_extra_elt=yes # Function ELT + ### + ###<select elt(2,'ONE','TWO','THREE') + ###>TWO +func_extra_encrypt=yes # Function ENCRYPT + ### + ###<select encrypt('hello') + ###>tHrzZO8Aq1FG6 +func_extra_expand2arg=no # Function EXPAND + ### + ###<select expand('abcd',6) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd',6)' at line 1 +func_extra_field=yes # Function FIELD + ### + ###<select field('IBM','NCA','ICL','SUN','IBM','DIGITAL') + ###>4 +func_extra_fixed=no # Function FIXED + ### + ###<select fixed(222.6666,10,2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(222.6666,10,2)' at line 1 +func_extra_float=no # Function FLOAT + ### + ###<select float(6666.66,4) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'float(6666.66,4)' at line 1 +func_extra_format=yes # Function FORMAT + ### + ###<select format(1234.5555,2) + ###>1,234.56 +func_extra_from_days=yes # Function FROM_DAYS + ### + ###<select from_days(729024) from crash_me_d + ###>1996-01-01 +func_extra_from_unixtime=yes # Function FROM_UNIXTIME + ### + ###<select from_unixtime(0) from crash_me_d + ###>1970-01-01 02:00:00 +func_extra_getdate=no # Function GETDATE + ### + ###<select getdate() + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '()' at line 1 +func_extra_greatest=yes # Function GREATEST + ### + ###<select greatest('HARRY','HARRIOT','HAROLD') + ###>HARRY +func_extra_hex=yes # Function HEX + ### + ###<select HEX('A') + ###>41 +func_extra_if=yes # Function IF + ### + ###<select if(5,6,7) + ###>6 +func_extra_in_num=yes # Function IN on numbers in SELECT + ### + ###<select 2 in (3,2,5,9,5,1) + ###>1 +func_extra_in_str=yes # Function IN on strings in SELECT + ### + ###<select 'monty' in ('david','monty','allan') + ###>1 +func_extra_index=no # Function INDEX + ### + ###<select index('abcdefg','cd',1,1) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'index('abcdefg','cd',1,1)' at line 1 +func_extra_initcap=no # Function INITCAP + ### + ###<select initcap('the soap') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('the soap')' at line 1 +func_extra_instr=yes # Function LOCATE as INSTR + ### + ###<select instr('hello','ll') + ###>3 +func_extra_instr_oracle=no # Function INSTR (Oracle syntax) + ### + ###<select INSTR('CORPORATE FLOOR','OR',3,2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '3,2)' at line 1 +func_extra_instrb=no # Function INSTRB + ### + ###<select INSTRB('CORPORATE FLOOR','OR',5,2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('CORPORATE FLOOR','OR',5,2)' at line 1 +func_extra_interval=yes # Function INTERVAL + ### + ###<select interval(55,10,20,30,40,50,60,70,80,90,100) + ###>5 +func_extra_last_day=no # Function LAST_DAY + ### + ###<select last_day('1997-04-01') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1997-04-01') from crash_me_d' at line 1 +func_extra_last_insert_id=yes # Function LAST_INSERT_ID + ### + ###<select last_insert_id() + ###>0 +func_extra_least=yes # Function LEAST + ### + ###<select least('HARRY','HARRIOT','HAROLD') + ###>HAROLD +func_extra_length=error # Function LENGTH + ### + ###<select length(1) + ###>1 + ###We expected '2' but got '1' +func_extra_lengthb=no # Function LENGTHB + ### + ###<select lengthb('CANDIDE') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('CANDIDE')' at line 1 +func_extra_lfill3arg=no # Function LFILL (3 arg) + ### + ###<select lfill('abcd','.',6) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd','.',6)' at line 1 +func_extra_like=yes # Function LIKE in SELECT + ### + ###<select 'a' like 'a%' + ###>1 +func_extra_like_escape=yes # Function LIKE ESCAPE in SELECT + ### + ###<select '%' like 'a%' escape 'a' + ###>1 +func_extra_ln=yes # Function LN + ### + ###<select ln(95) + ###>4.553877 +func_extra_log(m_n)=yes # Function LOG(m,n) + ### + ###<select log(10,100) + ###>2.000000 +func_extra_logn=no # Function LOGN + ### + ###<select logn(2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(2)' at line 1 +func_extra_lpad=yes # Function LPAD + ### + ###<select lpad('hi',4,'??') + ###>??hi +func_extra_ltrim2arg=no # Function LTRIM (2 arg) + ### + ###<select ltrim('..abcd..','.') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ''.')' at line 1 +func_extra_makedate=no # Function MAKEDATE + ### + ###<select MAKEDATE(1963,228) from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1963,228) from crash_me_d' at line 1 +func_extra_maketime=no # Function MAKETIME + ### + ###<select MAKETIME(20,02,12) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(20,02,12)' at line 1 +func_extra_mapchar=no # Function MAPCHAR + ### + ###<select mapchar('Aâ') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('Aâ')' at line 1 +func_extra_mdy=no # Function MDY + ### + ###<select mdy(7,1,1998) from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(7,1,1998) from crash_me_d' at line 1 +func_extra_microsecond=no # Function MICROSECOND + ### + ###<select MICROSECOND('19630816200212111111') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('19630816200212111111')' at line 1 +func_extra_mid=yes # Function SUBSTRING as MID + ### + ###<select mid('hello',3,2) + ###>ll +func_extra_months_between=no # Function MONTHS_BETWEEN + ### + ###<select months_between('1997-02-02','1997-01-01') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1997-02-02','1997-01-01') from crash_me_d' at line 1 +func_extra_noround=no # Function NOROUND + ###< select noround(22.6) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(22.6)' at line 1 +func_extra_not=yes # Function NOT in SELECT + ### + ###<select not 0 + ###>1 +func_extra_not_between=yes # Function NOT BETWEEN in SELECT + ### + ###<select 5 not between 4 and 6 + ###>0 +func_extra_not_like=yes # Function NOT LIKE in SELECT + ### + ###<select 'a' not like 'a%' + ###>0 +func_extra_num=no # Function NUM + ### + ###<select NUM('2123') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('2123')' at line 1 +func_extra_odbc_convert=no # Function ODBC CONVERT + ### + ###<select convert(5,SQL_CHAR) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SQL_CHAR)' at line 1 +func_extra_password=yes # Function PASSWORD + ### + ###<select password('hello') + ###>70de51425df9d787 +func_extra_paste=no # Function PASTE + ### + ###<select paste('ABCDEFG',3,2,'1234') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('ABCDEFG',3,2,'1234')' at line 1 +func_extra_patindex=no # Function PATINDEX + ### + ###<select patindex('%a%','crash') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('%a%','crash')' at line 1 +func_extra_period_add=yes # Function PERIOD_ADD + ### + ###<select period_add(9602,-12) from crash_me_d + ###>199502 +func_extra_period_diff=yes # Function PERIOD_DIFF + ### + ###<select period_diff(199505,199404) from crash_me_d + ###>13 +func_extra_pow=yes # Function POW + ### + ###<select pow(3,2) + ###>9.000000 +func_extra_range=no # Function RANGE + ### + ###<select range(a) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a)' at line 1 +func_extra_regexp=yes # Function REGEXP in SELECT + ### + ###<select 'a' regexp '^(a|b)*$' + ###>1 +func_extra_replace2arg=no # Function REPLACE (2 arg) + ### + ###<select replace('AbCd','bC') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1 +func_extra_replicate=no # Function REPLICATE + ### + ###<select replicate('a',5) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('a',5)' at line 1 +func_extra_reverse=yes # Function REVERSE + ### + ###<select reverse('abcd') + ###>dcba +func_extra_rfill3arg=no # Function RFILL (3 arg) + ### + ###<select rfill('abcd','.',6) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd','.',6)' at line 1 +func_extra_root=no # Function ROOT + ### + ###<select root(4) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(4)' at line 1 +func_extra_round1=yes # Function ROUND(1 arg) + ### + ###<select round(5.63) + ###>6 +func_extra_rpad=yes # Function RPAD + ### + ###<select rpad('hi',4,'??') + ###>hi?? +func_extra_rpad4arg=no # Function RPAD (4 arg) + ### + ###<select rpad('abcd',2,'+-',8) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '8)' at line 1 +func_extra_rtrim2arg=no # Function RTRIM (2 arg) + ### + ###<select rtrim('..abcd..','.') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ''.')' at line 1 +func_extra_sec_to_time=yes # Function SEC_TO_TIME + ### + ###<select sec_to_time(5001) + ###>01:23:21 +func_extra_sinh=no # Function SINH + ### + ###<select sinh(1) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1)' at line 1 +func_extra_str=no # Function STR + ### + ###<select str(123.45,5,1) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(123.45,5,1)' at line 1 +func_extra_strcmp=yes # Function STRCMP + ### + ###<select strcmp('abc','adc') + ###>-1 +func_extra_stuff=no # Function STUFF + ### + ###<select stuff('abc',2,3,'xyz') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abc',2,3,'xyz')' at line 1 +func_extra_subdate=no # Function SUBDATE + ### + ###<select SUBDATE('2002-12-04',3) from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '3) from crash_me_d' at line 1 +func_extra_substr2arg=no # Function SUBSTR (2 arg) + ### + ###<select substr('abcd',2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd',2)' at line 1 +func_extra_substr3arg=no # Function SUBSTR (3 arg) + ### + ###<select substr('abcd',2,2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd',2,2)' at line 1 +func_extra_substrb=no # Function SUBSTRB + ### + ###<select SUBSTRB('ABCDEFG',5,4.2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('ABCDEFG',5,4.2)' at line 1 +func_extra_substring_index=yes # Function SUBSTRING_INDEX + ### + ###<select substring_index('www.tcx.se','.',-2) + ###>tcx.se +func_extra_subtime=no # Function SUBTIME + ### + ###<select SUBTIME('20:02:15','00:00:03') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:15','00:00:03')' at line 1 +func_extra_sysdate=yes # Function SYSDATE + ### + ###<select sysdate() + ###>2003-08-27 19:55:21 +func_extra_tail=no # Function TAIL + ### + ###<select tail('ABCDEFG',3) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('ABCDEFG',3)' at line 1 +func_extra_tanh=no # Function TANH + ### + ###<select tanh(1) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1)' at line 1 +func_extra_time=no # Function TIME + ### + ###<select time('20:02:12') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:12')' at line 1 +func_extra_time_to_sec=yes # Function TIME_TO_SEC + ### + ###<select time_to_sec('01:23:21') + ###>5001 +func_extra_timediff=no # Function TIMEDIFF + ### + ###<select TIMEDIFF('20:02:15','20:02:12') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:15','20:02:12')' at line 1 +func_extra_timestamp=no # Function TIMESTAMP + ### + ###<select timestamp('19630816','00200212') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('19630816','00200212')' at line 1 +func_extra_to_days=yes # Function TO_DAYS + ### + ###<select to_days('1996-01-01') from crash_me_d + ###>729024 +func_extra_translate=no # Function TRANSLATE + ### + ###<select translate('abc','bc','de') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abc','bc','de')' at line 1 +func_extra_trim1arg=yes # Function TRIM (1 arg) + ### + ###<select trim(' abcd ') + ###>abcd +func_extra_trim2arg=no # Function TRIM (2 arg) + ### + ###<select trim('..abcd..','.') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ''.')' at line 1 +func_extra_trim_many_char=error # Function TRIM; Many char extension + ### + ###<select trim(':!' FROM ':abc!') + ###>:abc! + ###We expected 'abc' but got ':abc!' +func_extra_trim_substring=yes # Function TRIM; Substring extension + ### + ###<select trim('cb' FROM 'abccb') + ###>abc +func_extra_trunc=no # Function TRUNC + ### + ###<select trunc(18.18,-1) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(18.18,-1)' at line 1 +func_extra_trunc1arg=no # Function TRUNC (1 arg) + ### + ###<select trunc(222.6) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(222.6)' at line 1 +func_extra_uid=no # Function UID + ### + ###<select uid + ###> execute failed:Unknown column 'uid' in 'field list' +func_extra_unix_timestamp=yes # Function UNIX_TIMESTAMP + ### + ###<select unix_timestamp() + ###>1062003321 +func_extra_userenv=no # Function USERENV + ### + ###<select userenv + ###> execute failed:Unknown column 'userenv' in 'field list' +func_extra_value=no # Function VALUE + ### + ###<select value(NULL,'WALRUS') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(NULL,'WALRUS')' at line 1 +func_extra_version=yes # Function VERSION + ### + ###<select version() + ###>4.0.15-debug-log +func_extra_weekday=yes # Function WEEKDAY + ### + ###<select weekday('1997-11-29') from crash_me_d + ###>5 +func_extra_weekofyear=no # Function WEEKOFYEAR + ### + ###<select WEEKOFYEAR('1963-08-16') from crash_me_d + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1963-08-16') from crash_me_d' at line 1 +func_extra_|=yes # Function | (bitwise or) + ### + ###<select 1 | 2 + ###>3 +func_extra_||=yes # Function OR as '||' + ### + ###<select 1=0 || 1=1 + ###>1 +func_extra_~*=no # Function ~* (case insensitive compare) + ### + ###<select 'hi' ~* 'HI' + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '~* 'HI'' at line 1 +func_odbc_abs=yes # Function ABS + ### + ###<select abs(-5) + ###>5 +func_odbc_acos=yes # Function ACOS + ### + ###<select acos(0) + ###>1.570796 +func_odbc_ascii=yes # Function ASCII + ### + ###<select ASCII('A') + ###>65 +func_odbc_asin=yes # Function ASIN + ### + ###<select asin(1) + ###>1.570796 +func_odbc_atan=yes # Function ATAN + ### + ###<select atan(1) + ###>0.785398 +func_odbc_atan2=yes # Function ATAN2 + ### + ###<select atan2(1,0) + ###>1.570796 +func_odbc_ceiling=yes # Function CEILING + ### + ###<select ceiling(-4.5) + ###>-4 +func_odbc_char=yes # Function CHAR + ### + ###<select CHAR(65) + ###>A +func_odbc_concat=yes # Function CONCAT(2 arg) + ### + ###<select concat('a','b') + ###>ab +func_odbc_cos=yes # Function COS + ### + ###<select cos(0) + ###>1.000000 +func_odbc_cot=yes # Function COT + ### + ###<select cot(1) + ###>0.64209262 +func_odbc_curdate=yes # Function CURDATE + ### + ###<select curdate() + ###>2003-08-27 +func_odbc_curtime=yes # Function CURTIME + ### + ###<select curtime() + ###>19:55:21 +func_odbc_database=yes # Function DATABASE + ### + ###<select database() + ###>test +func_odbc_dayname=yes # Function DAYNAME + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select dayname(a) from crash_me_d + ###>Saturday +func_odbc_dayofmonth=yes # Function DAYOFMONTH + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select dayofmonth(a) from crash_me_d + ###>1 +func_odbc_dayofweek=yes # Function DAYOFWEEK + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select dayofweek(a) from crash_me_d + ###>7 +func_odbc_dayofyear=yes # Function DAYOFYEAR + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select dayofyear(a) from crash_me_d + ###>32 +func_odbc_degrees=yes # Function DEGREES + ### + ###<select degrees(6.283185) + ###>359.99998239991 +func_odbc_difference=no # Function DIFFERENCE() + ### + ###<select difference('abc','abe') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abc','abe')' at line 1 + ### + ###<select {fn difference('abc','abe') } + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abc','abe') }' at line 1 +func_odbc_exp=yes # Function EXP + ### + ###<select exp(1.0) + ###>2.718282 +func_odbc_floor=yes # Function FLOOR + ### + ###<select floor(2.5) + ###>2 +func_odbc_fn_left=yes # Function ODBC syntax LEFT & RIGHT + ### + ###<select { fn LEFT( { fn RIGHT('abcd',2) },1) } + ###>c +func_odbc_hour=yes # Function HOUR + ###< insert into crash_me_t values(20:08:16) + ### + ###<select hour('12:13:14') + ###>12 +func_odbc_hour_time=yes # Function ANSI HOUR + ###< insert into crash_me_t values(20:08:16) + ### + ###<select hour(TIME '12:13:14') + ###>12 +func_odbc_ifnull=yes # Function IFNULL + ### + ###<select ifnull(2,3) + ###>2 +func_odbc_insert=yes # Function INSERT + ### + ###<select insert('abcd',2,2,'ef') + ###>aefd +func_odbc_lcase=yes # Function LCASE + ### + ###<select lcase('ABC') + ###>abc +func_odbc_left=yes # Function LEFT + ### + ###<select left('abcd',2) + ###>ab +func_odbc_length=yes # Function REAL LENGTH + ### + ###<select length('abcd ') + ###>5 +func_odbc_length_without_space=error # Function ODBC LENGTH + ### + ###<select length('abcd ') + ###>5 + ###We expected '4' but got '5' + ### + ###<select {fn length('abcd ') } + ###>5 + ###We expected '4' but got '5' +func_odbc_locate_2=yes # Function LOCATE(2 arg) + ### + ###<select locate('bcd','abcd') + ###>2 +func_odbc_locate_3=yes # Function LOCATE(3 arg) + ### + ###<select locate('bcd','abcd',3) + ###>0 +func_odbc_log=yes # Function LOG + ### + ###<select log(2) + ###>0.693147 +func_odbc_log10=yes # Function LOG10 + ### + ###<select log10(10) + ###>1.000000 +func_odbc_ltrim=yes # Function LTRIM + ### + ###<select ltrim(' abcd') + ###>abcd +func_odbc_minute=yes # Function MINUTE + ###< insert into crash_me_t values(20:08:16) + ### + ###<select minute('12:13:14') + ###>13 +func_odbc_mod=yes # Function MOD + ### + ###<select mod(11,7) + ###>4 +func_odbc_month=yes # Function MONTH + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select month(a) from crash_me_d + ###>2 +func_odbc_monthname=yes # Function MONTHNAME + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select monthname(a) from crash_me_d + ###>February +func_odbc_now=yes # Function NOW + ### + ###<select now() + ###>2003-08-27 19:55:21 +func_odbc_pi=yes # Function PI + ### + ###<select pi() + ###>3.141593 +func_odbc_power=yes # Function POWER + ### + ###<select power(2,4) + ###>16.000000 +func_odbc_quarter=yes # Function QUARTER + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select quarter(a) from crash_me_d + ###>1 +func_odbc_radians=yes # Function RADIANS + ### + ###<select radians(360) + ###>6.2831853071796 +func_odbc_rand=yes # Function RAND + ### + ###<select rand(1) + ###>0.40540353712198 +func_odbc_repeat=yes # Function REPEAT + ### + ###<select repeat('ab',3) + ###>ababab +func_odbc_replace=yes # Function REPLACE + ### + ###<select replace('abbaab','ab','ba') + ###>bababa +func_odbc_right=yes # Function RIGHT + ### + ###<select right('abcd',2) + ###>cd +func_odbc_round=yes # Function ROUND(2 arg) + ### + ###<select round(5.63,2) + ###>5.63 +func_odbc_rtrim=yes # Function RTRIM + ### + ###<select rtrim(' abcd ') + ###> abcd +func_odbc_second=yes # Function SECOND + ###< insert into crash_me_t values(20:08:16) + ### + ###<select second('12:13:14') + ###>14 +func_odbc_sign=yes # Function SIGN + ### + ###<select sign(-5) + ###>-1 +func_odbc_sin=yes # Function SIN + ### + ###<select sin(1) + ###>0.841471 +func_odbc_soundex=yes # Function SOUNDEX + ### + ###<select soundex('hello') + ###>H400 +func_odbc_space=yes # Function SPACE + ### + ###<select space(5) + ###> +func_odbc_sqrt=yes # Function SQRT + ### + ###<select sqrt(4) + ###>2.000000 +func_odbc_substring=yes # Function ODBC SUBSTRING + ### + ###<select substring('abcd',3,2) + ###>cd +func_odbc_tan=yes # Function TAN + ### + ###<select tan(1) + ###>1.557408 +func_odbc_timestampadd=no # Function TIMESTAMPADD + ### + ###<select timestampadd(SQL_TSI_SECOND,1,'1997-01-01 00:00:00') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(SQL_TSI_SECOND,1,'1997-01-01 00:00:00')' at line 1 + ### + ###<select {fn timestampadd(SQL_TSI_SECOND,1,{ts '1997-01-01 00:00:00'}) } + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(SQL_TSI_SECOND,1,{ts '1997-01-01 00:00:00'}) }' at line 1 +func_odbc_timestampdiff=no # Function TIMESTAMPDIFF + ### + ###<select timestampdiff(SQL_TSI_SECOND,'1997-01-01 00:00:02', '1997-01-01 00:00:01') + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(SQL_TSI_SECOND,'1997-01-01 00:00:02', '1997-01-01 00:00:01')' + ### + ###<select {fn timestampdiff(SQL_TSI_SECOND,{ts '1997-01-01 00:00:02'}, {ts '1997-01-01 00:00:01'}) } + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(SQL_TSI_SECOND,{ts '1997-01-01 00:00:02'}, {ts '1997-01-01 00: +func_odbc_truncate=yes # Function TRUNCATE + ### + ###<select truncate(18.18,-1) + ###>10 +func_odbc_ucase=yes # Function UCASE + ### + ###<select ucase('abc') + ###>ABC +func_odbc_user()=yes # Function USER() + ### + ###<select user() + ###>monty@localhost +func_odbc_week=USA # WEEK + ###<select week('1997-02-01') + ###>4 + ###We expected '5' but got '4' +func_odbc_year=yes # Function YEAR + ###< insert into crash_me_d values('1997-02-01') + ### + ###<select year(a) from crash_me_d + ###>1997 +func_sql_+=yes # Function +, -, * and / + ### + ###<select 5*3-4/2+1 + ###>14.00 +func_sql_bit_length=yes # Function BIT_LENGTH + ### + ###<select bit_length('abc') + ###>24 +func_sql_cast=yes # Function CAST + ### + ###<select CAST(1 as CHAR) + ###>1 +func_sql_char_length=error # Function CHAR_LENGTH + ### + ###<select char_length(b) from crash_me + ###>1 + ###We expected '10' but got '1' +func_sql_char_length(constant)=yes # Function CHAR_LENGTH(constant) + ### + ###<select char_length('abcd') + ###>4 +func_sql_character_length=yes # Function CHARACTER_LENGTH + ### + ###<select character_length('abcd') + ###>4 +func_sql_coalesce=yes # Function COALESCE + ### + ###<select coalesce(NULL,'bcd','qwe') + ###>bcd +func_sql_concat_as_||=error # Function concatenation with || + ### + ###<select 'abc' || 'def' + ###>0 + ###We expected 'abcdef' but got '0' +func_sql_current_date=yes # Function CURRENT_DATE + ### + ###<select current_date + ###>2003-08-27 +func_sql_current_time=yes # Function CURRENT_TIME + ### + ###<select current_time + ###>19:55:21 +func_sql_current_timestamp=yes # Function CURRENT_TIMESTAMP + ### + ###<select current_timestamp + ###>2003-08-27 19:55:21 +func_sql_current_user=with_parenthesis # CURRENT_USER + ###< select CURRENT_USER + ###> execute error:Unknown column 'CURRENT_USER' in 'field list' + ### + ###< select CURRENT_USER() + ###> OK +func_sql_extract_sql=yes # Function EXTRACT + ### + ###<select extract(minute from timestamp '2000-02-23 18:43:12.987') + ###>43 +func_sql_localtime=yes # Function LOCALTIME + ### + ###<select localtime + ###>2003-08-27 19:55:21 +func_sql_localtimestamp=yes # Function LOCALTIMESTAMP + ### + ###<select localtimestamp + ###>2003-08-27 19:55:21 +func_sql_lower=yes # Function LOWER + ### + ###<select LOWER('ABC') + ###>abc +func_sql_nullif_num=yes # Function NULLIF with numbers + ### + ###<select NULLIF(NULLIF(1,2),1) + ###> +func_sql_nullif_string=yes # Function NULLIF with strings + ### + ###<select NULLIF(NULLIF('first','second'),'first') + ###> +func_sql_octet_length=yes # Function OCTET_LENGTH + ### + ###<select octet_length('abc') + ###>3 +func_sql_position=yes # Function POSITION + ### + ###<select position('ll' in 'hello') + ###>3 +func_sql_searched_case=yes # Function searched CASE + ### + ###<select case when 1 > 2 then 'false' when 2 > 1 then 'true' end + ###>true +func_sql_session_user=with_parenthesis # SESSION_USER + ###< select SESSION_USER + ###> execute error:Unknown column 'SESSION_USER' in 'field list' + ### + ###< select SESSION_USER() + ###> OK +func_sql_simple_case=yes # Function simple CASE + ### + ###<select case 2 when 1 then 'false' when 2 then 'true' end + ###>true +func_sql_substring=yes # Function ANSI SQL SUBSTRING + ### + ###<select substring('abcd' from 2 for 2) + ###>bc +func_sql_system_user=with_parenthesis # SYSTEM_USER + ###< select SYSTEM_USER + ###> execute error:Unknown column 'SYSTEM_USER' in 'field list' + ### + ###< select SYSTEM_USER() + ###> OK +func_sql_trim=yes # Function TRIM + ### + ###<select trim(trailing from trim(LEADING FROM ' abc ')) + ###>abc +func_sql_upper=yes # Function UPPER + ### + ###<select UPPER('abc') + ###>ABC +func_sql_user=with_parenthesis # USER + ###< select USER + ###> execute error:Unknown column 'USER' in 'field list' + ### + ###< select USER() + ###> OK +func_where_between=yes # Function BETWEEN + ### + ###<select a from crash_me where 5 between 4 and 6 + ###>1 +func_where_eq_all=no # Function = ALL + ### + ###<select a from crash_me where b =all (select b from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all (select b from crash_me)' at line 1 +func_where_eq_any=no # Function = ANY + ### + ###<select a from crash_me where b =any (select b from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(select b from crash_me)' at line 1 +func_where_eq_some=no # Function = SOME + ### + ###<select a from crash_me where b =some (select b from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(select b from crash_me)' at line 1 +func_where_exists=no # Function EXISTS + ### + ###<select a from crash_me where exists (select * from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'exists (select * from crash_me)' at line 1 +func_where_in_num=yes # Function IN on numbers + ### + ###<select a from crash_me where 2 in (3,2,5,9,5,1) + ###>1 +func_where_like=yes # Function LIKE + ### + ###<select a from crash_me where b like 'a%' + ###>1 +func_where_like_escape=yes # Function LIKE ESCAPE + ### + ###<select a from crash_me where b like '%' escape 'a' + ###>1 +func_where_match=no # Function MATCH + ### + ###<select a from crash_me where 1 match (select a from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'match (select a from crash_me)' at line 1 +func_where_match_unique=no # Function MATCH UNIQUE + ### + ###<select a from crash_me where 1 match unique (select a from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'match unique (select a from crash_me)' at line 1 +func_where_matches=no # Function MATCHES + ### + ###<select a from crash_me where b matcjhes 'a*' + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'matcjhes 'a*'' at line 1 +func_where_not_between=yes # Function NOT BETWEEN + ### + ###<select a from crash_me where 7 not between 4 and 6 + ###>1 +func_where_not_exists=no # Function NOT EXISTS + ### + ###<select a from crash_me where not exists (select * from crash_me where a = 2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'exists (select * from crash_me where a = 2)' at line 1 +func_where_not_like=yes # Function NOT LIKE + ### + ###<select a from crash_me where b not like 'b%' + ###>1 +func_where_not_unique=no # Function NOT UNIQUE + ### + ###<select a from crash_me where not unique (select * from crash_me where a = 2) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'unique (select * from crash_me where a = 2)' at line 1 +func_where_unique=no # Function UNIQUE + ### + ###<select a from crash_me where unique (select * from crash_me) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'unique (select * from crash_me)' at line 1 +functions=yes # Functions + ###< select 1+1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_by=yes # Group by + ###< select a from crash_me group by a + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_by_alias=yes # Group by alias + ###< select a as ab from crash_me group by ab + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_by_null=yes # Group on column with null values + ###< create table crash_q (s char(10)) + ###> OK + ###< insert into crash_q values(null) + ###> OK + ###< insert into crash_q values(null) + ###> OK + ### + ###<select count(*),s from crash_q group by s + ###>2 + ### + ###< drop table crash_q + ###> OK +group_by_position=yes # Group by position + ###< select a from crash_me group by 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_distinct_functions=yes # Group functions with distinct + ###< select count(distinct a) from crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_func_extra_bit_and=yes # Group function BIT_AND + ### + ###<select bit_and(a),a from crash_me group by a + ###>1 +group_func_extra_bit_or=yes # Group function BIT_OR + ### + ###<select bit_or(a),a from crash_me group by a + ###>1 +group_func_extra_count_distinct_list=yes # Group function COUNT(DISTINCT expr,expr,...) + ### + ###<select count(distinct a,b),a from crash_me group by a + ###>1 +group_func_extra_std=yes # Group function STD + ### + ###<select std(a),a from crash_me group by a + ###>0.0000 +group_func_extra_stddev=yes # Group function STDDEV + ### + ###<select stddev(a),a from crash_me group by a + ###>0.0000 +group_func_extra_variance=no # Group function VARIANCE + ### + ###<select variance(a),a from crash_me group by a + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a),a from crash_me group by a' at line 1 +group_func_sql_any=no # Group function ANY + ### + ###<select any(a),a from crash_me group by a + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a),a from crash_me group by a' at line 1 +group_func_sql_avg=yes # Group function AVG + ### + ###<select avg(a),a from crash_me group by a + ###>1.0000 +group_func_sql_count_*=yes # Group function COUNT (*) + ### + ###<select count(*),a from crash_me group by a + ###>1 +group_func_sql_count_column=yes # Group function COUNT column name + ### + ###<select count(a),a from crash_me group by a + ###>1 +group_func_sql_count_distinct=yes # Group function COUNT(DISTINCT expr) + ### + ###<select count(distinct a),a from crash_me group by a + ###>1 +group_func_sql_every=no # Group function EVERY + ### + ###<select every(a),a from crash_me group by a + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a),a from crash_me group by a' at line 1 +group_func_sql_max=yes # Group function MAX on numbers + ### + ###<select max(a),a from crash_me group by a + ###>1 +group_func_sql_max_str=yes # Group function MAX on strings + ### + ###<select max(b),a from crash_me group by a + ###>a +group_func_sql_min=yes # Group function MIN on numbers + ### + ###<select min(a),a from crash_me group by a + ###>1 +group_func_sql_min_str=yes # Group function MIN on strings + ### + ###<select min(b),a from crash_me group by a + ###>a +group_func_sql_some=no # Group function SOME + ### + ###<select some(a),a from crash_me group by a + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a),a from crash_me group by a' at line 1 +group_func_sql_sum=yes # Group function SUM + ### + ###<select sum(a),a from crash_me group by a + ###>1 +group_functions=yes # Group functions + ###< select count(*) from crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_many_distinct_functions=yes # Group functions with several distinct + ###< select count(distinct a), count(distinct b) from crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +group_on_unused=yes # Group on unused column + ###< select count(*) from crash_me group by a + ###> OK + ### + ###As far as all queries returned OK, result is YES +has_true_false=no # TRUE and FALSE + ###< select (1=1)=true + ###> execute error:Unknown column 'true' in 'field list' +having=yes # Having + ###<select a from crash_me group by a having a > 0 + ###>1 + ### + ###<select a from crash_me group by a having a < 0 + ###> didn't return any result: +having_with_alias=yes # Having on alias + ###< select a as ab from crash_me group by a having ab > 0 + ###> OK + ### + ###As far as all queries returned OK, result is YES +having_with_group=yes # Having with group function + ###< select a from crash_me group by a having count(*) = 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +hex_numbers=yes # hex numbers (0x41) + ###< select 0x41 + ###> OK + ### + ###As far as all queries returned OK, result is YES +hex_strings=yes # hex strings (x'1ace') + ###< select x'1ace' + ###> OK + ### + ###As far as all queries returned OK, result is YES +ignore_end_space=yes # Ignore end space in compare + ### + ###<select b from crash_me where b = 'a ' + ###>a +index_in_create=yes # index in create table + ###< create table crash_q (q integer not null,index (q)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +index_namespace=yes # different namespace for index + ###< create index crash_me on crash_me (b) + ###> OK + ###< drop index crash_me on crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +index_parts=yes # index on column part (extension) + ###< create index crash_q on crash_me (b(5)) + ###> OK + ###< drop index crash_q on crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +inner_join=yes # inner join + ###< select crash_me.a from crash_me inner join crash_me2 ON crash_me.a=crash_me2.a + ###> OK + ### + ###As far as all queries returned OK, result is YES +insert_default_values=no # INSERT DEFAULT VALUES + ###< create table crash_me_q (a int) + ###> OK + ###< insert into crash_me_q DEFAULT VALUES + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DEFAULT VALUES' at line 1 + ###< drop table crash_me_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +insert_empty_string=yes # insert empty string + ###< create table crash_q (a char(10) not null,b char(10)) + ###> OK + ###< insert into crash_q values ('','') + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +insert_multi_value=yes # INSERT with Value lists + ###< create table crash_q (s char(10)) + ###> OK + ###< insert into crash_q values ('a'),('b') + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +insert_select=yes # insert INTO ... SELECT ... + ###< create table crash_q (a int) + ###> OK + ###< insert into crash_q (a) SELECT crash_me.a from crash_me + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +insert_with_default=yes # INSERT with DEFAULT + ###< create table crash_me_q (a int) + ###> OK + ###< insert into crash_me_q (a) values (DEFAULT) + ###> OK + ###< drop table crash_me_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +insert_with_empty_value_list=no # INSERT with empty value list + ###< create table crash_me_q (a int) + ###> OK + ###< insert into crash_me_q (a) values () + ###> execute error:Column count doesn't match value count at row 1 + ###< drop table crash_me_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +insert_with_set=yes # INSERT with set syntax + ###< create table crash_q (a integer) + ###> OK + ###< insert into crash_q SET a=1 + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +intersect=no # intersect + ###< select * from crash_me intersect select * from crash_me3 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me3' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +intersect_all=no # intersect all + ###< select * from crash_me intersect all select * from crash_me3 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all select * from crash_me3' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +intersect_all_incompat=no # intersect all (incompatible lists) + ###< select * from crash_me intersect all select * from crash_me2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all select * from crash_me2' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +intersect_incompat=no # intersect (incompatible lists) + ###< select * from crash_me intersect select * from crash_me2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me2' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +join_tables=31 # tables in join + ###We are trying (example with N=5): + ###select crash_me.a,t0.a,t1.a,t2.a,t3.a,t4.a from crash_me,crash_me t0,crash_me t1,crash_me t2,crash_me t3,crash_me t4 + ### 32:FAIL 7:OK 19:OK 25:OK 28:OK 30:OK 31:FAIL +left_outer_join=yes # left outer join + ###< select crash_me.a from crash_me left join crash_me2 ON crash_me.a=crash_me2.a + ###> OK + ### + ###As far as all queries returned OK, result is YES +left_outer_join_using=yes # left outer join using + ###< select c1 from crash_me left join crash_me2 using (a) + ###> OK + ### + ###As far as all queries returned OK, result is YES +length_of_varchar_field=actual length # CHARACTER_LENGTH(varchar_field) + ###< CREATE TABLE crash_me1 (S1 VARCHAR(100)) + ###> OK + ###< INSERT INTO crash_me1 VALUES ('X') + ###> OK + ### + ###< SELECT CHARACTER_LENGTH(S1) FROM crash_me1 + ### > 1 + ###< drop table crash_me1 + ###> OK +like_with_column=yes # column LIKE column + ###< create table crash_q (a char(10),b char(10)) + ###> OK + ###< insert into crash_q values('abc','abc') + ###> OK + ###< select * from crash_q where a like b + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +like_with_number=yes # LIKE on numbers + ###< create table crash_q (a int,b int) + ###> OK + ###< insert into crash_q values(10,10) + ###> OK + ###< select * from crash_q where a like '10' + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +lock_tables=yes # lock table + ###< lock table crash_me READ + ###> OK + ###< unlock tables + ###> OK + ### + ###As far as all queries returned OK, result is YES +logical_value=1 # Value of logical operation (1=1) + ###<select (1=1) + ###>1 +max_big_expressions=10 # big expressions + ###We are trying (example with N=5): + ###select 0+(1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+...(14308) + ### 50:FAIL 10:OK 30:FAIL 14:FAIL 11:FAIL +max_char_size=255 # max char() size + ###We are trying (example with N=5): + ###create table crash_q (q char(5)) + ###insert into crash_q values ('aaaaa') + ###select * from crash_q + ### 524287:FAIL 104858:FAIL 20972:FAIL 4195:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK +max_column_name=64 # column name length + ###We are trying (example with N=5): + ###create table crash_q (qaaaaa integer) + ###insert into crash_q (qaaaaa) values(1) + ###select qaaaaa from crash_q + ### 256:FAIL 51:OK 153:FAIL 72:FAIL 55:OK 63:OK 67:FAIL 64:FAIL +max_columns=3398 # Columns in table + ###We are trying (example with N=5): + ###create table crash_q (a integer ,a0 integer,a1 integer,a2 integer,a3 integer,a4 integer) + ### 4096:FAIL 819:OK 2457:OK 3276:OK 3686:FAIL 3358:OK 3522:FAIL 3391:OK 3456:FAIL 3404:FAIL 3394:OK 3399:FAIL 3395:OK 3397:OK 3398:FAIL +max_conditions=85660 # OR and AND in WHERE + ###We are trying (example with N=5): + ###select a from crash_me where a=1 and b='a' or a=0 and b='0' or a=1 and b='1' or a=2 and b='2' or a=3 and b='3' or a=4 and b='4' + ### 27592:OK 41389:OK 48287:FAIL 42769:OK 45528:FAIL 43321:FAIL 42880:FAIL 42791:OK 42835:FAIL 42800:OK 42817:OK 42826:OK 42830:OK 42832:FAIL 42831:FAIL +max_expressions=1450 # simple expressions + ###We are trying (example with N=5): + ###select 1+1+1+1+1+1 + ### 5000:FAIL 1000:OK 3000:FAIL 1400:OK 2200:FAIL 1560:FAIL 1432:OK 1496:FAIL 1445:OK 1470:FAIL 1450:OK 1460:FAIL 1452:FAIL 1451:FAIL +max_index=32 # max index + ### max_unique_index=32 ,so max_index must be same +max_index_length=500 # index length + ###We are trying (example with N=5): + ###create table crash_q (q0 char(5) not null,unique (q0)) + ###insert into crash_q values('aaaaa') + ### 4096:FAIL 819:FAIL 164:OK 491:OK 655:FAIL 524:FAIL 498:OK 511:FAIL 501:FAIL 499:OK 500:OK +max_index_name=64 # index name length + ###We are trying (example with N=5): + ###create index crash_qaaaaa on crash_me (a) + ### 256:FAIL 51:OK 153:FAIL 72:FAIL 55:OK 63:FAIL 57:OK 60:FAIL 58:FAIL +max_index_part_length=255 # max index part length + ###We are trying (example with N=5): + ###create table crash_q (q char(5) not null,unique(q)) + ###insert into crash_q (q) values ('aaaaa') + ###select q from crash_q +max_index_parts=16 # index parts + ###We are trying (example with N=5): + ###create table crash_q (q0 integer not null,q1 integer not null,q2 integer not null,q3 integer not null,q4 integer not nul...(1263) + ###insert into crash_q (q0,q1,q2,q3,q4,q5,q6,q7,q8,q9,q10,q11,q12,q13,q14,q15,q16,q17,q18,q19,q20,q21,q22,q23,q24,q25,q26,q...(284) + ###select q0 from crash_q + ### 32:FAIL 7:OK 19:FAIL 10:OK 14:OK 16:FAIL 15:OK +max_index_varchar_part_length=255 # index varchar part length + ###We are trying (example with N=5): + ###create table crash_q (q varchar(5) not null,unique(q)) + ###insert into crash_q (q) values ('aaaaa') + ###select q from crash_q +max_row_length=65534 # max table row length (without blobs) + ###We are trying (example with N=5): + ###create table crash_q (q0 char(5) not null) + ###insert into crash_q values ('aaaaa') + ### 433245:FAIL 86649:FAIL 17330:OK 51989:OK 69319:FAIL 55455:OK 62387:OK 65853:FAIL 63080:OK 64466:OK 65159:OK 65506:OK 65679:FAIL 65541:FAIL 65513:OK 65527:OK 65534:OK 65537:FAIL 65535:FAIL +max_row_length_with_null=65502 # table row length with nulls (without blobs) + ###We are trying (example with N=5): + ###create table crash_q (q0 char(5) ) + ###insert into crash_q values ('aaaaa') + ### 65534:FAIL 13107:OK 39320:OK 52427:OK 58980:OK 62257:OK 63895:OK 64714:OK 65124:OK 65329:OK 65431:OK 65482:OK 65508:FAIL 65487:OK 65497:OK 65502:OK 65505:FAIL 65503:FAIL +max_select_alias_name=+512 # select alias name length + ###We are trying (example with N=5): + ###select b as aaaaa from crash_me +max_stack_expression=1450 # stacked expressions + ###We are trying (example with N=5): + ###select 1+(1+(1+(1+(1+(1))))) + ### 1000:OK 1500:FAIL 1100:OK 1300:OK 1400:OK 1450:OK 1475:FAIL 1455:FAIL 1451:FAIL +max_table_alias_name=+512 # table alias name length + ###We are trying (example with N=5): + ###select aaaaa.b from crash_me aaaaa +max_table_name=64 # table name length + ###We are trying (example with N=5): + ###create table crash_qaaaaa (q integer) + ###insert into crash_qaaaaa values(1) + ###select * from crash_qaaaaa + ### 256:FAIL 51:OK 153:FAIL 72:FAIL 55:OK 63:FAIL 57:OK 60:FAIL 58:FAIL +max_text_size=1048543 # max text or blob size + ###We are trying (example with N=5): + ###create table crash_q (q mediumtext) + ###insert into crash_q values ('aaaaa') + ###select * from crash_q + ### 524272:OK 786408:OK 917476:OK 983010:OK 1015777:OK 1032161:OK 1040353:OK 1044449:OK 1046497:OK 1047521:OK 1048033:OK 1048289:OK 1048417:OK 1048481:OK 1048513:OK 1048529:OK 1048537:OK 1048541:OK 1048543:OK 1048544:FAIL +max_unique_index=32 # unique indexes + ###We are trying (example with N=5): + ###create table crash_q (q integer,q1 integer not null,unique (q1),q2 integer not null,unique (q2),q3 integer not null,uniq...(72) + ###insert into crash_q (q,q1,q2,q3,q4,q5) values (1,1,1,1,1,1) + ###select q from crash_q + ### 32:OK 48:FAIL 35:FAIL 33:FAIL +max_varchar_size=255 # max varchar() size + ###We are trying (example with N=5): + ###create table crash_q (q varchar(5)) + ###insert into crash_q values ('aaaaa') + ###select * from crash_q + ### 524287:FAIL 104858:FAIL 20972:FAIL 4195:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK +minus=no # minus + ###< select * from crash_me minus select * from crash_me3 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me3' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +minus_incompat=no # minus (incompatible lists) + ###< select * from crash_me minus select * from crash_me2 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me2' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +minus_neg=yes # Calculate 1--1 + ### + ###<select a--1 from crash_me + ###>2 +multi_drop=yes # many tables to drop table + ###< create table crash_q (a int) + ###> OK + ###< create table crash_q2 (a int) + ###> OK + ###< drop table crash_q,crash_q2 + ###> OK + ### + ###As far as all queries returned OK, result is YES +multi_null_in_unique=yes # null in unique index + ###< create table crash_q (q integer, x integer,unique (q)) + ###> OK + ###< insert into crash_q(x) values(1) + ###> OK + ###< insert into crash_q(x) values(2) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +multi_strings=yes # Multiple line strings + ### + ###<select a from crash_me where b < 'a' + ###'b' + ###>1 +multi_table_delete=yes # DELETE FROM table1,table2... + ###< create table crash_q (a integer,b char(10)) + ###> OK + ###< insert into crash_q values(1,'c') + ###> OK + ###< delete crash_q.* from crash_q,crash_me where crash_q.a=crash_me.a + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +multi_table_update=yes # Update with many tables + ###< create table crash_q (a integer,b char(10)) + ###> OK + ###< insert into crash_q values(1,'c') + ###> OK + ###< update crash_q left join crash_me on crash_q.a=crash_me.a set crash_q.b=crash_me.b + ###> OK + ### + ###<select b from crash_q + ###>a + ### + ###< drop table crash_q + ###> OK +natural_join=yes # natural join + ###< select * from crash_me natural join crash_me3 + ###> OK + ### + ###As far as all queries returned OK, result is YES +natural_join_incompat=yes # natural join (incompatible lists) + ###< select c1 from crash_me natural join crash_me2 + ###> OK + ### + ###As far as all queries returned OK, result is YES +natural_left_outer_join=yes # natural left outer join + ###< select c1 from crash_me natural left join crash_me2 + ###> OK + ### + ###As far as all queries returned OK, result is YES +no_primary_key=yes # Tables without primary key + ###< create table crash_me (a integer not null,b char(10) not null) + ###> OK + ###< insert into crash_me (a,b) values (1,'a') + ###> OK +not_id_between=no # NOT ID BETWEEN interprets as ID NOT BETWEEN + ###< create table crash_me_b (i int) + ###> OK + ###< insert into crash_me_b values(2) + ###> OK + ###< insert into crash_me_b values(5) + ###> OK + ### + ###<select i from crash_me_b where not i between 1 and 3 + ###> didn't return any result: + ### + ###< drop table crash_me_b + ###> OK +null_concat_expr=yes # Is concat('a',NULL) = NULL + ### + ###<select concat('a',NULL) + ###> +null_in_index=yes # null in index + ###< create table crash_q (a char(10),index (a)) + ###> OK + ###< insert into crash_q values (NULL) + ###> OK + ### + ###<select * from crash_q + ###> + ### + ###< drop table crash_q + ###> OK +null_in_unique=yes # null in unique index + ###< create table crash_q (q integer,unique (q)) + ###> OK + ###< insert into crash_q (q) values(NULL) + ###> OK + ###< insert into crash_q (q) values(NULL) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +null_num_expr=yes # Is 1+NULL = NULL + ### + ###<select 1+NULL + ###> +nulls_in_unique=yes # null combination in unique index + ###< create table crash_q (q integer,q1 integer,unique (q,q1)) + ###> OK + ###< insert into crash_q (q,q1) values(1,NULL) + ###> OK + ###< insert into crash_q (q,q1) values(1,NULL) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +odbc_left_outer_join=yes # left outer join odbc style + ###< select crash_me.a from { oj crash_me left outer join crash_me2 ON crash_me.a=crash_me2.a } + ###> OK + ### + ###As far as all queries returned OK, result is YES +operating_system=Linux 2.4.20-64GB-SMP i686 # crash-me tested on +order_by=yes # Order by + ###< select a from crash_me order by a + ###> OK + ### + ###As far as all queries returned OK, result is YES +order_by_alias=yes # Order by alias + ###< select a as ab from crash_me order by ab + ###> OK + ### + ###As far as all queries returned OK, result is YES +order_by_function=yes # Order by function + ###< select a from crash_me order by a+1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +order_by_position=yes # Order by position + ###< select a from crash_me order by 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +order_on_unused=yes # Order by on unused column + ###< select b from crash_me order by a + ###> OK + ### + ###As far as all queries returned OK, result is YES +position_of_null=first # Where is null values in sorted recordset + ###< insert into crash_me_n (i) values(1) + ###> OK + ###< insert into crash_me_n values(2,2) + ###> OK + ###< insert into crash_me_n values(3,3) + ###> OK + ###< insert into crash_me_n values(4,4) + ###> OK + ###< insert into crash_me_n (i) values(5) + ###> OK + ### + ###< select r from crash_me_n order by r + ###> + ###> + ###> 2 + ###> 3 + ###> 4 +position_of_null_desc=last # Where is null values in sorted recordset (DESC) + ###< select r from crash_me_n order by r desc + ###> 4 + ###> 3 + ###> 2 + ###> + ###> +primary_key_in_create=yes # primary key in create table + ###< create table crash_q (q integer not null,primary key (q)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +psm_functions=no # PSM functions (ANSI SQL) + ###< create table crash_q (a int) + ###> OK + ###< create function crash_func(in a1 int, in b1 int) returns int language sql deterministic contains sql begin return a1 * b1; end + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(in a1 int, in b1 int) returns int language sql deterministic c + ###< insert into crash_q values(crash_func(2,4)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(2,4))' at line 1 + ###< select a,crash_func(a,2) from crash_q + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a,2) from crash_q' at line 1 + ###< drop function crash_func cascade + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'cascade' at line 1 + ###< drop table crash_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +psm_modules=no # PSM modules (ANSI SQL) + ###< create table crash_q (a int,b int) + ###> OK + ###< create module crash_m declare procedure crash_proc(in a1 int, in b1 int) language sql modifies sql data begin declare c1 int; set c1 = a1 + b1; insert into crash_q(a,b) values (a1,c1); end; declare procedure crash_proc2(INOUT a int, in b int) contains sql set a = b + 10; end module + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'module crash_m declare procedure crash_proc(in a1 int, in b1 in + ###< call crash_proc(1,10) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'call crash_proc(1,10)' at line 1 + ###< drop module crash_m cascade + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'module crash_m cascade' at line 1 + ###< drop table crash_q cascade + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +psm_procedures=no # PSM procedures (ANSI SQL) + ###< create table crash_q (a int,b int) + ###> OK + ###< create procedure crash_proc(in a1 int, in b1 int) language sql modifies sql data begin declare c1 int; set c1 = a1 + b1; insert into crash_q(a,b) values (a1,c1); end + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'procedure crash_proc(in a1 int, in b1 int) language sql modifie + ###< call crash_proc(1,10) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'call crash_proc(1,10)' at line 1 + ###< drop procedure crash_proc + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'procedure crash_proc' at line 1 + ###< drop table crash_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +psm_trigger=no # Triggers (ANSI SQL) + ###< create table crash_q (a int ,b int) + ###> OK + ###< create trigger crash_trigger after insert on crash_q referencing new table as new_a when (localtime > time '18:00:00') begin atomic end + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'trigger crash_trigger after insert on crash_q referencing new t + ###< insert into crash_q values(1,2) + ###> OK + ###< drop trigger crash_trigger + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'trigger crash_trigger' at line 1 + ###< drop table crash_q + ###> OK + ### + ###As far as some queries didnt return OK, result is NO +query_size=1048574 # query size +quote_ident_with_"=error # " as identifier quote (ANSI SQL) + ### + ###<select "A" from crash_me + ###>A + ###We expected '1' but got 'A' +quote_ident_with_[=no # [] as identifier quote + ### + ###<select [A] from crash_me + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '[A] from crash_me' at line 1 +quote_ident_with_`=yes # ` as identifier quote + ### + ###<select `A` from crash_me + ###>1 +quote_ident_with_dbl_"=no # Double "" in identifiers as " + ###< create table crash_me1 ("abc""d" integer) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '"abc""d" integer)' at line 1 + ###< drop table crash_me1 + ###> execute error:Unknown table 'crash_me1' + ### + ###As far as some queries didnt return OK, result is NO +quote_with_"=yes # Allows ' and " as string markers + ###< select a from crash_me where b<"c" + ###> OK + ### + ###As far as all queries returned OK, result is YES +remember_end_space=no # Remembers end space in char() + ###< create table crash_q (a char(10)) + ###> OK + ###< insert into crash_q values('hello ') + ###> OK + ### + ###<select a from crash_q where a = 'hello ' + ###>hello + ###We expected 'hello ' but got 'hello' + ### + ###< drop table crash_q + ###> OK +remember_end_space_varchar=no # Remembers end space in varchar() + ###< create table crash_q (a varchar(10)) + ###> OK + ###< insert into crash_q values('hello ') + ###> OK + ### + ###<select a from crash_q where a = 'hello ' + ###>hello + ###We expected 'hello ' but got 'hello' + ### + ###< drop table crash_q + ###> OK +rename_table=yes # rename table + ###< create table crash_q (a integer, b integer,c1 CHAR(10)) + ###> OK + ###< rename table crash_q to crash_q1 + ###> OK + ###< drop table crash_q1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +repeat_string_size=1047552 # return string size from function + ###We are trying (example with N=5): + ###select repeat('a',5) + ### 4000000:FAIL 800000:OK 2400000:FAIL 1120000:FAIL 864000:OK 992000:OK 1056000:FAIL 1004800:OK 1030400:OK 1043200:OK 1049600:FAIL 1044480:OK 1047040:OK 1048320:FAIL 1047296:OK 1047808:FAIL 1047399:OK 1047603:FAIL 1047440:OK 1047521:OK 1047562:FAIL 1047529:OK 1047545:OK 1047553:FAIL 1047547:OK 1047550:OK 1047551:OK 1047552:OK +reserved_word_ansi-92/99_absolute=no # Keyword ABSOLUTE + ###< create table crash_me10 (ABSOLUTE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_action=no # Keyword ACTION + ###< create table crash_me10 (ACTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_add=yes # Keyword ADD + ###< create table crash_me10 (ADD int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ADD int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_after=no # Keyword AFTER + ###< create table crash_me10 (AFTER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_alias=no # Keyword ALIAS + ###< create table crash_me10 (ALIAS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_all=yes # Keyword ALL + ###< create table crash_me10 (ALL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ALL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_allocate=no # Keyword ALLOCATE + ###< create table crash_me10 (ALLOCATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_alter=yes # Keyword ALTER + ###< create table crash_me10 (ALTER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ALTER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_and=yes # Keyword AND + ###< create table crash_me10 (AND int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'AND int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_any=no # Keyword ANY + ###< create table crash_me10 (ANY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_are=no # Keyword ARE + ###< create table crash_me10 (ARE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_as=yes # Keyword AS + ###< create table crash_me10 (AS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'AS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_asc=yes # Keyword ASC + ###< create table crash_me10 (ASC int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ASC int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_assertion=no # Keyword ASSERTION + ###< create table crash_me10 (ASSERTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_at=no # Keyword AT + ###< create table crash_me10 (AT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_authorization=no # Keyword AUTHORIZATION + ###< create table crash_me10 (AUTHORIZATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_before=no # Keyword BEFORE + ###< create table crash_me10 (BEFORE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_begin=no # Keyword BEGIN + ###< create table crash_me10 (BEGIN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_bit=no # Keyword BIT + ###< create table crash_me10 (BIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_boolean=no # Keyword BOOLEAN + ###< create table crash_me10 (BOOLEAN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_both=yes # Keyword BOTH + ###< create table crash_me10 (BOTH int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BOTH int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_breadth=no # Keyword BREADTH + ###< create table crash_me10 (BREADTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_by=yes # Keyword BY + ###< create table crash_me10 (BY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_call=no # Keyword CALL + ###< create table crash_me10 (CALL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_cascade=yes # Keyword CASCADE + ###< create table crash_me10 (CASCADE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CASCADE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_cascaded=no # Keyword CASCADED + ###< create table crash_me10 (CASCADED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_case=yes # Keyword CASE + ###< create table crash_me10 (CASE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CASE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_cast=no # Keyword CAST + ###< create table crash_me10 (CAST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_catalog=no # Keyword CATALOG + ###< create table crash_me10 (CATALOG int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_char=yes # Keyword CHAR + ###< create table crash_me10 (CHAR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CHAR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_character=yes # Keyword CHARACTER + ###< create table crash_me10 (CHARACTER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CHARACTER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_check=yes # Keyword CHECK + ###< create table crash_me10 (CHECK int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_close=no # Keyword CLOSE + ###< create table crash_me10 (CLOSE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_collate=no # Keyword COLLATE + ###< create table crash_me10 (COLLATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_collation=no # Keyword COLLATION + ###< create table crash_me10 (COLLATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_column=yes # Keyword COLUMN + ###< create table crash_me10 (COLUMN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'COLUMN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_commit=no # Keyword COMMIT + ###< create table crash_me10 (COMMIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_completion=no # Keyword COMPLETION + ###< create table crash_me10 (COMPLETION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_connect=no # Keyword CONNECT + ###< create table crash_me10 (CONNECT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_connection=no # Keyword CONNECTION + ###< create table crash_me10 (CONNECTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_constraint=yes # Keyword CONSTRAINT + ###< create table crash_me10 (CONSTRAINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_constraints=no # Keyword CONSTRAINTS + ###< create table crash_me10 (CONSTRAINTS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_continue=no # Keyword CONTINUE + ###< create table crash_me10 (CONTINUE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_corresponding=no # Keyword CORRESPONDING + ###< create table crash_me10 (CORRESPONDING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_create=yes # Keyword CREATE + ###< create table crash_me10 (CREATE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CREATE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_cross=yes # Keyword CROSS + ###< create table crash_me10 (CROSS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CROSS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_current=no # Keyword CURRENT + ###< create table crash_me10 (CURRENT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_current_date=yes # Keyword CURRENT_DATE + ###< create table crash_me10 (CURRENT_DATE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CURRENT_DATE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_current_time=yes # Keyword CURRENT_TIME + ###< create table crash_me10 (CURRENT_TIME int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CURRENT_TIME int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_current_timestamp=yes # Keyword CURRENT_TIMESTAMP + ###< create table crash_me10 (CURRENT_TIMESTAMP int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CURRENT_TIMESTAMP int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_current_user=no # Keyword CURRENT_USER + ###< create table crash_me10 (CURRENT_USER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_cursor=no # Keyword CURSOR + ###< create table crash_me10 (CURSOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_cycle=no # Keyword CYCLE + ###< create table crash_me10 (CYCLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_data=no # Keyword DATA + ###< create table crash_me10 (DATA int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_date=no # Keyword DATE + ###< create table crash_me10 (DATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_day=no # Keyword DAY + ###< create table crash_me10 (DAY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_deallocate=no # Keyword DEALLOCATE + ###< create table crash_me10 (DEALLOCATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_dec=yes # Keyword DEC + ###< create table crash_me10 (DEC int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DEC int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_decimal=yes # Keyword DECIMAL + ###< create table crash_me10 (DECIMAL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DECIMAL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_declare=no # Keyword DECLARE + ###< create table crash_me10 (DECLARE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_default=yes # Keyword DEFAULT + ###< create table crash_me10 (DEFAULT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DEFAULT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_deferrable=no # Keyword DEFERRABLE + ###< create table crash_me10 (DEFERRABLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_deferred=no # Keyword DEFERRED + ###< create table crash_me10 (DEFERRED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_delete=yes # Keyword DELETE + ###< create table crash_me10 (DELETE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DELETE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_depth=no # Keyword DEPTH + ###< create table crash_me10 (DEPTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_desc=yes # Keyword DESC + ###< create table crash_me10 (DESC int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DESC int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_describe=yes # Keyword DESCRIBE + ###< create table crash_me10 (DESCRIBE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DESCRIBE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_descriptor=no # Keyword DESCRIPTOR + ###< create table crash_me10 (DESCRIPTOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_diagnostics=no # Keyword DIAGNOSTICS + ###< create table crash_me10 (DIAGNOSTICS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_dictionary=no # Keyword DICTIONARY + ###< create table crash_me10 (DICTIONARY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_disconnect=no # Keyword DISCONNECT + ###< create table crash_me10 (DISCONNECT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_distinct=yes # Keyword DISTINCT + ###< create table crash_me10 (DISTINCT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DISTINCT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_domain=no # Keyword DOMAIN + ###< create table crash_me10 (DOMAIN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_double=yes # Keyword DOUBLE + ###< create table crash_me10 (DOUBLE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DOUBLE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_drop=yes # Keyword DROP + ###< create table crash_me10 (DROP int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DROP int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_each=no # Keyword EACH + ###< create table crash_me10 (EACH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_else=yes # Keyword ELSE + ###< create table crash_me10 (ELSE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ELSE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_elseif=no # Keyword ELSEIF + ###< create table crash_me10 (ELSEIF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_end=no # Keyword END + ###< create table crash_me10 (END int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_end-exec=yes # Keyword END-EXEC + ###< create table crash_me10 (END-EXEC int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '-EXEC int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_equals=no # Keyword EQUALS + ###< create table crash_me10 (EQUALS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_escape=no # Keyword ESCAPE + ###< create table crash_me10 (ESCAPE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_except=no # Keyword EXCEPT + ###< create table crash_me10 (EXCEPT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_exception=no # Keyword EXCEPTION + ###< create table crash_me10 (EXCEPTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_exec=no # Keyword EXEC + ###< create table crash_me10 (EXEC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_execute=no # Keyword EXECUTE + ###< create table crash_me10 (EXECUTE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_external=no # Keyword EXTERNAL + ###< create table crash_me10 (EXTERNAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_false=no # Keyword FALSE + ###< create table crash_me10 (FALSE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_fetch=no # Keyword FETCH + ###< create table crash_me10 (FETCH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_first=no # Keyword FIRST + ###< create table crash_me10 (FIRST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_float=yes # Keyword FLOAT + ###< create table crash_me10 (FLOAT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FLOAT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_for=yes # Keyword FOR + ###< create table crash_me10 (FOR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FOR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_foreign=yes # Keyword FOREIGN + ###< create table crash_me10 (FOREIGN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_found=no # Keyword FOUND + ###< create table crash_me10 (FOUND int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_from=yes # Keyword FROM + ###< create table crash_me10 (FROM int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FROM int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_full=no # Keyword FULL + ###< create table crash_me10 (FULL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_general=no # Keyword GENERAL + ###< create table crash_me10 (GENERAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_get=no # Keyword GET + ###< create table crash_me10 (GET int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_global=no # Keyword GLOBAL + ###< create table crash_me10 (GLOBAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_go=no # Keyword GO + ###< create table crash_me10 (GO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_goto=no # Keyword GOTO + ###< create table crash_me10 (GOTO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_grant=yes # Keyword GRANT + ###< create table crash_me10 (GRANT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'GRANT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_group=yes # Keyword GROUP + ###< create table crash_me10 (GROUP int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'GROUP int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_having=yes # Keyword HAVING + ###< create table crash_me10 (HAVING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'HAVING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_hour=no # Keyword HOUR + ###< create table crash_me10 (HOUR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_identity=no # Keyword IDENTITY + ###< create table crash_me10 (IDENTITY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_if=yes # Keyword IF + ###< create table crash_me10 (IF int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'IF int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_ignore=yes # Keyword IGNORE + ###< create table crash_me10 (IGNORE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'IGNORE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_immediate=no # Keyword IMMEDIATE + ###< create table crash_me10 (IMMEDIATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_in=yes # Keyword IN + ###< create table crash_me10 (IN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'IN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_indicator=no # Keyword INDICATOR + ###< create table crash_me10 (INDICATOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_initially=no # Keyword INITIALLY + ###< create table crash_me10 (INITIALLY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_inner=yes # Keyword INNER + ###< create table crash_me10 (INNER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INNER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_input=no # Keyword INPUT + ###< create table crash_me10 (INPUT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_insert=yes # Keyword INSERT + ###< create table crash_me10 (INSERT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INSERT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_int=yes # Keyword INT + ###< create table crash_me10 (INT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_integer=yes # Keyword INTEGER + ###< create table crash_me10 (INTEGER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INTEGER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_intersect=no # Keyword INTERSECT + ###< create table crash_me10 (INTERSECT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_interval=yes # Keyword INTERVAL + ###< create table crash_me10 (INTERVAL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INTERVAL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_into=yes # Keyword INTO + ###< create table crash_me10 (INTO int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INTO int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_is=yes # Keyword IS + ###< create table crash_me10 (IS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'IS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_isolation=no # Keyword ISOLATION + ###< create table crash_me10 (ISOLATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_join=yes # Keyword JOIN + ###< create table crash_me10 (JOIN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'JOIN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_key=yes # Keyword KEY + ###< create table crash_me10 (KEY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_language=no # Keyword LANGUAGE + ###< create table crash_me10 (LANGUAGE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_last=no # Keyword LAST + ###< create table crash_me10 (LAST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_leading=yes # Keyword LEADING + ###< create table crash_me10 (LEADING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LEADING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_leave=no # Keyword LEAVE + ###< create table crash_me10 (LEAVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_left=yes # Keyword LEFT + ###< create table crash_me10 (LEFT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LEFT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_less=no # Keyword LESS + ###< create table crash_me10 (LESS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_level=no # Keyword LEVEL + ###< create table crash_me10 (LEVEL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_like=yes # Keyword LIKE + ###< create table crash_me10 (LIKE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LIKE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_limit=yes # Keyword LIMIT + ###< create table crash_me10 (LIMIT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LIMIT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_local=no # Keyword LOCAL + ###< create table crash_me10 (LOCAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_loop=no # Keyword LOOP + ###< create table crash_me10 (LOOP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_match=yes # Keyword MATCH + ###< create table crash_me10 (MATCH int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MATCH int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_minute=no # Keyword MINUTE + ###< create table crash_me10 (MINUTE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_modify=no # Keyword MODIFY + ###< create table crash_me10 (MODIFY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_module=no # Keyword MODULE + ###< create table crash_me10 (MODULE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_month=no # Keyword MONTH + ###< create table crash_me10 (MONTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_names=no # Keyword NAMES + ###< create table crash_me10 (NAMES int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_national=no # Keyword NATIONAL + ###< create table crash_me10 (NATIONAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_natural=yes # Keyword NATURAL + ###< create table crash_me10 (NATURAL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'NATURAL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_nchar=no # Keyword NCHAR + ###< create table crash_me10 (NCHAR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_new=no # Keyword NEW + ###< create table crash_me10 (NEW int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_next=no # Keyword NEXT + ###< create table crash_me10 (NEXT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_no=no # Keyword NO + ###< create table crash_me10 (NO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_none=no # Keyword NONE + ###< create table crash_me10 (NONE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_not=yes # Keyword NOT + ###< create table crash_me10 (NOT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'NOT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_null=yes # Keyword NULL + ###< create table crash_me10 (NULL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'NULL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_numeric=yes # Keyword NUMERIC + ###< create table crash_me10 (NUMERIC int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'NUMERIC int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_object=no # Keyword OBJECT + ###< create table crash_me10 (OBJECT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_of=no # Keyword OF + ###< create table crash_me10 (OF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_off=no # Keyword OFF + ###< create table crash_me10 (OFF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_old=no # Keyword OLD + ###< create table crash_me10 (OLD int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_on=yes # Keyword ON + ###< create table crash_me10 (ON int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ON int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_only=no # Keyword ONLY + ###< create table crash_me10 (ONLY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_open=no # Keyword OPEN + ###< create table crash_me10 (OPEN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_operation=no # Keyword OPERATION + ###< create table crash_me10 (OPERATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_option=yes # Keyword OPTION + ###< create table crash_me10 (OPTION int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTION int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_or=yes # Keyword OR + ###< create table crash_me10 (OR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_order=yes # Keyword ORDER + ###< create table crash_me10 (ORDER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ORDER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_outer=yes # Keyword OUTER + ###< create table crash_me10 (OUTER int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OUTER int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_output=no # Keyword OUTPUT + ###< create table crash_me10 (OUTPUT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_pad=no # Keyword PAD + ###< create table crash_me10 (PAD int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_parameters=no # Keyword PARAMETERS + ###< create table crash_me10 (PARAMETERS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_partial=yes # Keyword PARTIAL + ###< create table crash_me10 (PARTIAL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PARTIAL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_precision=yes # Keyword PRECISION + ###< create table crash_me10 (PRECISION int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PRECISION int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_preorder=no # Keyword PREORDER + ###< create table crash_me10 (PREORDER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_prepare=no # Keyword PREPARE + ###< create table crash_me10 (PREPARE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_preserve=no # Keyword PRESERVE + ###< create table crash_me10 (PRESERVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_primary=yes # Keyword PRIMARY + ###< create table crash_me10 (PRIMARY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_prior=no # Keyword PRIOR + ###< create table crash_me10 (PRIOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_privileges=yes # Keyword PRIVILEGES + ###< create table crash_me10 (PRIVILEGES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PRIVILEGES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_procedure=yes # Keyword PROCEDURE + ###< create table crash_me10 (PROCEDURE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PROCEDURE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_public=no # Keyword PUBLIC + ###< create table crash_me10 (PUBLIC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_read=yes # Keyword READ + ###< create table crash_me10 (READ int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'READ int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_real=yes # Keyword REAL + ###< create table crash_me10 (REAL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REAL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_recursive=no # Keyword RECURSIVE + ###< create table crash_me10 (RECURSIVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_ref=no # Keyword REF + ###< create table crash_me10 (REF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_references=yes # Keyword REFERENCES + ###< create table crash_me10 (REFERENCES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REFERENCES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_referencing=no # Keyword REFERENCING + ###< create table crash_me10 (REFERENCING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_relative=no # Keyword RELATIVE + ###< create table crash_me10 (RELATIVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_resignal=no # Keyword RESIGNAL + ###< create table crash_me10 (RESIGNAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_restrict=yes # Keyword RESTRICT + ###< create table crash_me10 (RESTRICT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'RESTRICT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_return=no # Keyword RETURN + ###< create table crash_me10 (RETURN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_returns=yes # Keyword RETURNS + ###< create table crash_me10 (RETURNS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'RETURNS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_revoke=yes # Keyword REVOKE + ###< create table crash_me10 (REVOKE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REVOKE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_right=yes # Keyword RIGHT + ###< create table crash_me10 (RIGHT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'RIGHT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_role=no # Keyword ROLE + ###< create table crash_me10 (ROLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_rollback=no # Keyword ROLLBACK + ###< create table crash_me10 (ROLLBACK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_routine=no # Keyword ROUTINE + ###< create table crash_me10 (ROUTINE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_row=no # Keyword ROW + ###< create table crash_me10 (ROW int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_rows=no # Keyword ROWS + ###< create table crash_me10 (ROWS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_savepoint=no # Keyword SAVEPOINT + ###< create table crash_me10 (SAVEPOINT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_schema=no # Keyword SCHEMA + ###< create table crash_me10 (SCHEMA int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_scroll=no # Keyword SCROLL + ###< create table crash_me10 (SCROLL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_search=no # Keyword SEARCH + ###< create table crash_me10 (SEARCH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_second=no # Keyword SECOND + ###< create table crash_me10 (SECOND int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_section=no # Keyword SECTION + ###< create table crash_me10 (SECTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_select=yes # Keyword SELECT + ###< create table crash_me10 (SELECT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_sequence=no # Keyword SEQUENCE + ###< create table crash_me10 (SEQUENCE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_session=no # Keyword SESSION + ###< create table crash_me10 (SESSION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_session_user=no # Keyword SESSION_USER + ###< create table crash_me10 (SESSION_USER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_set=yes # Keyword SET + ###< create table crash_me10 (SET int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SET int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_signal=no # Keyword SIGNAL + ###< create table crash_me10 (SIGNAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_size=no # Keyword SIZE + ###< create table crash_me10 (SIZE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_smallint=yes # Keyword SMALLINT + ###< create table crash_me10 (SMALLINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SMALLINT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_some=no # Keyword SOME + ###< create table crash_me10 (SOME int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_space=no # Keyword SPACE + ###< create table crash_me10 (SPACE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_sql=no # Keyword SQL + ###< create table crash_me10 (SQL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_sqlexception=no # Keyword SQLEXCEPTION + ###< create table crash_me10 (SQLEXCEPTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_sqlstate=no # Keyword SQLSTATE + ###< create table crash_me10 (SQLSTATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_sqlwarning=no # Keyword SQLWARNING + ###< create table crash_me10 (SQLWARNING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_structure=no # Keyword STRUCTURE + ###< create table crash_me10 (STRUCTURE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_system_user=no # Keyword SYSTEM_USER + ###< create table crash_me10 (SYSTEM_USER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_table=yes # Keyword TABLE + ###< create table crash_me10 (TABLE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TABLE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_temporary=no # Keyword TEMPORARY + ###< create table crash_me10 (TEMPORARY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_then=yes # Keyword THEN + ###< create table crash_me10 (THEN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'THEN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_time=no # Keyword TIME + ###< create table crash_me10 (TIME int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_timestamp=no # Keyword TIMESTAMP + ###< create table crash_me10 (TIMESTAMP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_timezone_hour=no # Keyword TIMEZONE_HOUR + ###< create table crash_me10 (TIMEZONE_HOUR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_timezone_minute=no # Keyword TIMEZONE_MINUTE + ###< create table crash_me10 (TIMEZONE_MINUTE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_to=yes # Keyword TO + ###< create table crash_me10 (TO int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TO int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_trailing=yes # Keyword TRAILING + ###< create table crash_me10 (TRAILING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TRAILING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_transaction=no # Keyword TRANSACTION + ###< create table crash_me10 (TRANSACTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_translation=no # Keyword TRANSLATION + ###< create table crash_me10 (TRANSLATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_trigger=no # Keyword TRIGGER + ###< create table crash_me10 (TRIGGER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_true=no # Keyword TRUE + ###< create table crash_me10 (TRUE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_under=no # Keyword UNDER + ###< create table crash_me10 (UNDER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_union=yes # Keyword UNION + ###< create table crash_me10 (UNION int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'UNION int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_unique=yes # Keyword UNIQUE + ###< create table crash_me10 (UNIQUE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_unknown=no # Keyword UNKNOWN + ###< create table crash_me10 (UNKNOWN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_update=yes # Keyword UPDATE + ###< create table crash_me10 (UPDATE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'UPDATE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_usage=yes # Keyword USAGE + ###< create table crash_me10 (USAGE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'USAGE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_user=no # Keyword USER + ###< create table crash_me10 (USER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_using=yes # Keyword USING + ###< create table crash_me10 (USING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'USING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_value=no # Keyword VALUE + ###< create table crash_me10 (VALUE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_values=yes # Keyword VALUES + ###< create table crash_me10 (VALUES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'VALUES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_varchar=yes # Keyword VARCHAR + ###< create table crash_me10 (VARCHAR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'VARCHAR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_variable=no # Keyword VARIABLE + ###< create table crash_me10 (VARIABLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_varying=yes # Keyword VARYING + ###< create table crash_me10 (VARYING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'VARYING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_view=no # Keyword VIEW + ###< create table crash_me10 (VIEW int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_when=yes # Keyword WHEN + ###< create table crash_me10 (WHEN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHEN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_whenever=no # Keyword WHENEVER + ###< create table crash_me10 (WHENEVER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_where=yes # Keyword WHERE + ###< create table crash_me10 (WHERE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_while=no # Keyword WHILE + ###< create table crash_me10 (WHILE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_with=yes # Keyword WITH + ###< create table crash_me10 (WITH int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'WITH int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_without=no # Keyword WITHOUT + ###< create table crash_me10 (WITHOUT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_work=no # Keyword WORK + ###< create table crash_me10 (WORK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_write=yes # Keyword WRITE + ###< create table crash_me10 (WRITE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'WRITE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi-92/99_year=no # Keyword YEAR + ###< create table crash_me10 (YEAR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi-92/99_zone=no # Keyword ZONE + ###< create table crash_me10 (ZONE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_async=no # Keyword ASYNC + ###< create table crash_me10 (ASYNC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_avg=no # Keyword AVG + ###< create table crash_me10 (AVG int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_between=yes # Keyword BETWEEN + ###< create table crash_me10 (BETWEEN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BETWEEN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi92_bit_length=no # Keyword BIT_LENGTH + ###< create table crash_me10 (BIT_LENGTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_char_length=no # Keyword CHAR_LENGTH + ###< create table crash_me10 (CHAR_LENGTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_character_length=no # Keyword CHARACTER_LENGTH + ###< create table crash_me10 (CHARACTER_LENGTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_coalesce=no # Keyword COALESCE + ###< create table crash_me10 (COALESCE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_convert=no # Keyword CONVERT + ###< create table crash_me10 (CONVERT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_count=no # Keyword COUNT + ###< create table crash_me10 (COUNT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_exists=yes # Keyword EXISTS + ###< create table crash_me10 (EXISTS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'EXISTS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi92_extract=no # Keyword EXTRACT + ###< create table crash_me10 (EXTRACT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_insensitive=no # Keyword INSENSITIVE + ###< create table crash_me10 (INSENSITIVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_lower=no # Keyword LOWER + ###< create table crash_me10 (LOWER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_max=no # Keyword MAX + ###< create table crash_me10 (MAX int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_min=no # Keyword MIN + ###< create table crash_me10 (MIN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_nullif=no # Keyword NULLIF + ###< create table crash_me10 (NULLIF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_octet_length=no # Keyword OCTET_LENGTH + ###< create table crash_me10 (OCTET_LENGTH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_oid=no # Keyword OID + ###< create table crash_me10 (OID int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_operators=no # Keyword OPERATORS + ###< create table crash_me10 (OPERATORS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_others=no # Keyword OTHERS + ###< create table crash_me10 (OTHERS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_overlaps=no # Keyword OVERLAPS + ###< create table crash_me10 (OVERLAPS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_pendant=no # Keyword PENDANT + ###< create table crash_me10 (PENDANT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_position=no # Keyword POSITION + ###< create table crash_me10 (POSITION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_private=no # Keyword PRIVATE + ###< create table crash_me10 (PRIVATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_protected=no # Keyword PROTECTED + ###< create table crash_me10 (PROTECTED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_replace=yes # Keyword REPLACE + ###< create table crash_me10 (REPLACE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REPLACE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi92_sensitive=no # Keyword SENSITIVE + ###< create table crash_me10 (SENSITIVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_similar=no # Keyword SIMILAR + ###< create table crash_me10 (SIMILAR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_sqlcode=no # Keyword SQLCODE + ###< create table crash_me10 (SQLCODE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_sqlerror=no # Keyword SQLERROR + ###< create table crash_me10 (SQLERROR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_substring=no # Keyword SUBSTRING + ###< create table crash_me10 (SUBSTRING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_sum=no # Keyword SUM + ###< create table crash_me10 (SUM int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_test=no # Keyword TEST + ###< create table crash_me10 (TEST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_there=no # Keyword THERE + ###< create table crash_me10 (THERE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_translate=no # Keyword TRANSLATE + ###< create table crash_me10 (TRANSLATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_trim=no # Keyword TRIM + ###< create table crash_me10 (TRIM int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_type=no # Keyword TYPE + ###< create table crash_me10 (TYPE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_upper=no # Keyword UPPER + ###< create table crash_me10 (UPPER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_virtual=no # Keyword VIRTUAL + ###< create table crash_me10 (VIRTUAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_visible=no # Keyword VISIBLE + ###< create table crash_me10 (VISIBLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi92_wait=no # Keyword WAIT + ###< create table crash_me10 (WAIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_admin=no # Keyword ADMIN + ###< create table crash_me10 (ADMIN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_aggregate=no # Keyword AGGREGATE + ###< create table crash_me10 (AGGREGATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_array=no # Keyword ARRAY + ###< create table crash_me10 (ARRAY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_binary=yes # Keyword BINARY + ###< create table crash_me10 (BINARY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BINARY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi99_blob=yes # Keyword BLOB + ###< create table crash_me10 (BLOB int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BLOB int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi99_class=no # Keyword CLASS + ###< create table crash_me10 (CLASS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_clob=no # Keyword CLOB + ###< create table crash_me10 (CLOB int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_condition=no # Keyword CONDITION + ###< create table crash_me10 (CONDITION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_constructor=no # Keyword CONSTRUCTOR + ###< create table crash_me10 (CONSTRUCTOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_contains=no # Keyword CONTAINS + ###< create table crash_me10 (CONTAINS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_cube=no # Keyword CUBE + ###< create table crash_me10 (CUBE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_current_path=no # Keyword CURRENT_PATH + ###< create table crash_me10 (CURRENT_PATH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_current_role=no # Keyword CURRENT_ROLE + ###< create table crash_me10 (CURRENT_ROLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_datalink=no # Keyword DATALINK + ###< create table crash_me10 (DATALINK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_deref=no # Keyword DEREF + ###< create table crash_me10 (DEREF int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_destroy=no # Keyword DESTROY + ###< create table crash_me10 (DESTROY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_destructor=no # Keyword DESTRUCTOR + ###< create table crash_me10 (DESTRUCTOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_deterministic=no # Keyword DETERMINISTIC + ###< create table crash_me10 (DETERMINISTIC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_do=no # Keyword DO + ###< create table crash_me10 (DO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_dynamic=no # Keyword DYNAMIC + ###< create table crash_me10 (DYNAMIC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_every=no # Keyword EVERY + ###< create table crash_me10 (EVERY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_exit=no # Keyword EXIT + ###< create table crash_me10 (EXIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_expand=no # Keyword EXPAND + ###< create table crash_me10 (EXPAND int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_expanding=no # Keyword EXPANDING + ###< create table crash_me10 (EXPANDING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_free=no # Keyword FREE + ###< create table crash_me10 (FREE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_function=no # Keyword FUNCTION + ###< create table crash_me10 (FUNCTION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_grouping=no # Keyword GROUPING + ###< create table crash_me10 (GROUPING int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_handler=no # Keyword HANDLER + ###< create table crash_me10 (HANDLER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_hast=no # Keyword HAST + ###< create table crash_me10 (HAST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_host=no # Keyword HOST + ###< create table crash_me10 (HOST int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_initialize=no # Keyword INITIALIZE + ###< create table crash_me10 (INITIALIZE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_inout=no # Keyword INOUT + ###< create table crash_me10 (INOUT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_iterate=no # Keyword ITERATE + ###< create table crash_me10 (ITERATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_large=no # Keyword LARGE + ###< create table crash_me10 (LARGE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_lateral=no # Keyword LATERAL + ###< create table crash_me10 (LATERAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_localtime=yes # Keyword LOCALTIME + ###< create table crash_me10 (LOCALTIME int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOCALTIME int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi99_localtimestamp=yes # Keyword LOCALTIMESTAMP + ###< create table crash_me10 (LOCALTIMESTAMP int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOCALTIMESTAMP int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_ansi99_locator=no # Keyword LOCATOR + ###< create table crash_me10 (LOCATOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_meets=no # Keyword MEETS + ###< create table crash_me10 (MEETS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_modifies=no # Keyword MODIFIES + ###< create table crash_me10 (MODIFIES int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_nclob=no # Keyword NCLOB + ###< create table crash_me10 (NCLOB int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_normalize=no # Keyword NORMALIZE + ###< create table crash_me10 (NORMALIZE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_ordinality=no # Keyword ORDINALITY + ###< create table crash_me10 (ORDINALITY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_out=no # Keyword OUT + ###< create table crash_me10 (OUT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_parameter=no # Keyword PARAMETER + ###< create table crash_me10 (PARAMETER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_path=no # Keyword PATH + ###< create table crash_me10 (PATH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_period=no # Keyword PERIOD + ###< create table crash_me10 (PERIOD int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_postfix=no # Keyword POSTFIX + ###< create table crash_me10 (POSTFIX int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_precedes=no # Keyword PRECEDES + ###< create table crash_me10 (PRECEDES int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_prefix=no # Keyword PREFIX + ###< create table crash_me10 (PREFIX int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_reads=no # Keyword READS + ###< create table crash_me10 (READS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_redo=no # Keyword REDO + ###< create table crash_me10 (REDO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_repeat=no # Keyword REPEAT + ###< create table crash_me10 (REPEAT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_result=no # Keyword RESULT + ###< create table crash_me10 (RESULT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_rollup=no # Keyword ROLLUP + ###< create table crash_me10 (ROLLUP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_sets=no # Keyword SETS + ###< create table crash_me10 (SETS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_specific=no # Keyword SPECIFIC + ###< create table crash_me10 (SPECIFIC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_specifictype=no # Keyword SPECIFICTYPE + ###< create table crash_me10 (SPECIFICTYPE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_start=no # Keyword START + ###< create table crash_me10 (START int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_state=no # Keyword STATE + ###< create table crash_me10 (STATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_static=no # Keyword STATIC + ###< create table crash_me10 (STATIC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_succeeds=no # Keyword SUCCEEDS + ###< create table crash_me10 (SUCCEEDS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_terminate=no # Keyword TERMINATE + ###< create table crash_me10 (TERMINATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_than=no # Keyword THAN + ###< create table crash_me10 (THAN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_treat=no # Keyword TREAT + ###< create table crash_me10 (TREAT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_undo=no # Keyword UNDO + ###< create table crash_me10 (UNDO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_ansi99_until=no # Keyword UNTIL + ###< create table crash_me10 (UNTIL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_access=no # Keyword ACCESS + ###< create table crash_me10 (ACCESS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_analyze=yes # Keyword ANALYZE + ###< create table crash_me10 (ANALYZE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ANALYZE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_audit=no # Keyword AUDIT + ###< create table crash_me10 (AUDIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_auto_increment=no # Keyword AUTO_INCREMENT + ###< create table crash_me10 (AUTO_INCREMENT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_backup=no # Keyword BACKUP + ###< create table crash_me10 (BACKUP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_bdb=no # Keyword BDB + ###< create table crash_me10 (BDB int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_berkeleydb=no # Keyword BERKELEYDB + ###< create table crash_me10 (BERKELEYDB int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_bigint=yes # Keyword BIGINT + ###< create table crash_me10 (BIGINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BIGINT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_break=no # Keyword BREAK + ###< create table crash_me10 (BREAK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_browse=no # Keyword BROWSE + ###< create table crash_me10 (BROWSE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_btree=no # Keyword BTREE + ###< create table crash_me10 (BTREE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_bulk=no # Keyword BULK + ###< create table crash_me10 (BULK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_change=yes # Keyword CHANGE + ###< create table crash_me10 (CHANGE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CHANGE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_checkpoint=no # Keyword CHECKPOINT + ###< create table crash_me10 (CHECKPOINT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_cluster=no # Keyword CLUSTER + ###< create table crash_me10 (CLUSTER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_clustered=no # Keyword CLUSTERED + ###< create table crash_me10 (CLUSTERED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_columns=yes # Keyword COLUMNS + ###< create table crash_me10 (COLUMNS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'COLUMNS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_comment=no # Keyword COMMENT + ###< create table crash_me10 (COMMENT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_compress=no # Keyword COMPRESS + ###< create table crash_me10 (COMPRESS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_compute=no # Keyword COMPUTE + ###< create table crash_me10 (COMPUTE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_containstable=no # Keyword CONTAINSTABLE + ###< create table crash_me10 (CONTAINSTABLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_database=yes # Keyword DATABASE + ###< create table crash_me10 (DATABASE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DATABASE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_databases=yes # Keyword DATABASES + ###< create table crash_me10 (DATABASES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DATABASES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_day_hour=yes # Keyword DAY_HOUR + ###< create table crash_me10 (DAY_HOUR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DAY_HOUR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_day_minute=yes # Keyword DAY_MINUTE + ###< create table crash_me10 (DAY_MINUTE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DAY_MINUTE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_day_second=yes # Keyword DAY_SECOND + ###< create table crash_me10 (DAY_SECOND int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DAY_SECOND int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_dbcc=no # Keyword DBCC + ###< create table crash_me10 (DBCC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_delayed=yes # Keyword DELAYED + ###< create table crash_me10 (DELAYED int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DELAYED int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_deny=no # Keyword DENY + ###< create table crash_me10 (DENY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_disk=no # Keyword DISK + ###< create table crash_me10 (DISK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_distinctrow=yes # Keyword DISTINCTROW + ###< create table crash_me10 (DISTINCTROW int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'DISTINCTROW int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_distributed=no # Keyword DISTRIBUTED + ###< create table crash_me10 (DISTRIBUTED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_dummy=no # Keyword DUMMY + ###< create table crash_me10 (DUMMY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_dump=no # Keyword DUMP + ###< create table crash_me10 (DUMP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_enclosed=yes # Keyword ENCLOSED + ###< create table crash_me10 (ENCLOSED int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ENCLOSED int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_errlvl=no # Keyword ERRLVL + ###< create table crash_me10 (ERRLVL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_errors=no # Keyword ERRORS + ###< create table crash_me10 (ERRORS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_escaped=yes # Keyword ESCAPED + ###< create table crash_me10 (ESCAPED int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ESCAPED int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_exclusive=no # Keyword EXCLUSIVE + ###< create table crash_me10 (EXCLUSIVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_explain=yes # Keyword EXPLAIN + ###< create table crash_me10 (EXPLAIN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'EXPLAIN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_fields=yes # Keyword FIELDS + ###< create table crash_me10 (FIELDS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FIELDS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_file=no # Keyword FILE + ###< create table crash_me10 (FILE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_fillfactor=no # Keyword FILLFACTOR + ###< create table crash_me10 (FILLFACTOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_freetext=no # Keyword FREETEXT + ###< create table crash_me10 (FREETEXT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_freetexttable=no # Keyword FREETEXTTABLE + ###< create table crash_me10 (FREETEXTTABLE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_fulltext=yes # Keyword FULLTEXT + ###< create table crash_me10 (FULLTEXT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_geometry=no # Keyword GEOMETRY + ###< create table crash_me10 (GEOMETRY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_hash=no # Keyword HASH + ###< create table crash_me10 (HASH int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_high_priority=yes # Keyword HIGH_PRIORITY + ###< create table crash_me10 (HIGH_PRIORITY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'HIGH_PRIORITY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_holdlock=no # Keyword HOLDLOCK + ###< create table crash_me10 (HOLDLOCK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_hour_minute=yes # Keyword HOUR_MINUTE + ###< create table crash_me10 (HOUR_MINUTE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'HOUR_MINUTE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_hour_second=yes # Keyword HOUR_SECOND + ###< create table crash_me10 (HOUR_SECOND int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'HOUR_SECOND int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_identified=no # Keyword IDENTIFIED + ###< create table crash_me10 (IDENTIFIED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_identity_insert=no # Keyword IDENTITY_INSERT + ###< create table crash_me10 (IDENTITY_INSERT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_identitycol=no # Keyword IDENTITYCOL + ###< create table crash_me10 (IDENTITYCOL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_increment=no # Keyword INCREMENT + ###< create table crash_me10 (INCREMENT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_index=yes # Keyword INDEX + ###< create table crash_me10 (INDEX int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_infile=yes # Keyword INFILE + ###< create table crash_me10 (INFILE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'INFILE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_initial=no # Keyword INITIAL + ###< create table crash_me10 (INITIAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_innodb=no # Keyword INNODB + ###< create table crash_me10 (INNODB int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_keys=yes # Keyword KEYS + ###< create table crash_me10 (KEYS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'KEYS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_kill=yes # Keyword KILL + ###< create table crash_me10 (KILL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'KILL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_lineno=no # Keyword LINENO + ###< create table crash_me10 (LINENO int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_lines=yes # Keyword LINES + ###< create table crash_me10 (LINES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LINES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_load=yes # Keyword LOAD + ###< create table crash_me10 (LOAD int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOAD int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_lock=yes # Keyword LOCK + ###< create table crash_me10 (LOCK int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOCK int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_long=yes # Keyword LONG + ###< create table crash_me10 (LONG int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LONG int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_longblob=yes # Keyword LONGBLOB + ###< create table crash_me10 (LONGBLOB int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LONGBLOB int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_longtext=yes # Keyword LONGTEXT + ###< create table crash_me10 (LONGTEXT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LONGTEXT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_low_priority=yes # Keyword LOW_PRIORITY + ###< create table crash_me10 (LOW_PRIORITY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LOW_PRIORITY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_master_server_id=yes # Keyword MASTER_SERVER_ID + ###< create table crash_me10 (MASTER_SERVER_ID int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MASTER_SERVER_ID int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_maxextents=no # Keyword MAXEXTENTS + ###< create table crash_me10 (MAXEXTENTS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_mediumblob=yes # Keyword MEDIUMBLOB + ###< create table crash_me10 (MEDIUMBLOB int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MEDIUMBLOB int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_mediumint=yes # Keyword MEDIUMINT + ###< create table crash_me10 (MEDIUMINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MEDIUMINT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_mediumtext=yes # Keyword MEDIUMTEXT + ###< create table crash_me10 (MEDIUMTEXT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MEDIUMTEXT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_middleint=yes # Keyword MIDDLEINT + ###< create table crash_me10 (MIDDLEINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MIDDLEINT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_minus=no # Keyword MINUS + ###< create table crash_me10 (MINUS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_minute_second=yes # Keyword MINUTE_SECOND + ###< create table crash_me10 (MINUTE_SECOND int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MINUTE_SECOND int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_mlslabel=no # Keyword MLSLABEL + ###< create table crash_me10 (MLSLABEL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_mode=no # Keyword MODE + ###< create table crash_me10 (MODE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_mrg_myisam=no # Keyword MRG_MYISAM + ###< create table crash_me10 (MRG_MYISAM int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_noaudit=no # Keyword NOAUDIT + ###< create table crash_me10 (NOAUDIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_nocheck=no # Keyword NOCHECK + ###< create table crash_me10 (NOCHECK int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_nocompress=no # Keyword NOCOMPRESS + ###< create table crash_me10 (NOCOMPRESS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_nonclustered=no # Keyword NONCLUSTERED + ###< create table crash_me10 (NONCLUSTERED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_nowait=no # Keyword NOWAIT + ###< create table crash_me10 (NOWAIT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_number=no # Keyword NUMBER + ###< create table crash_me10 (NUMBER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_offline=no # Keyword OFFLINE + ###< create table crash_me10 (OFFLINE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_offsets=no # Keyword OFFSETS + ###< create table crash_me10 (OFFSETS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_online=no # Keyword ONLINE + ###< create table crash_me10 (ONLINE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_opendatasource=no # Keyword OPENDATASOURCE + ###< create table crash_me10 (OPENDATASOURCE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_openquery=no # Keyword OPENQUERY + ###< create table crash_me10 (OPENQUERY int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_openrowset=no # Keyword OPENROWSET + ###< create table crash_me10 (OPENROWSET int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_openxml=no # Keyword OPENXML + ###< create table crash_me10 (OPENXML int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_optimize=yes # Keyword OPTIMIZE + ###< create table crash_me10 (OPTIMIZE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTIMIZE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_optionally=yes # Keyword OPTIONALLY + ###< create table crash_me10 (OPTIONALLY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OPTIONALLY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_outfile=yes # Keyword OUTFILE + ###< create table crash_me10 (OUTFILE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'OUTFILE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_over=no # Keyword OVER + ###< create table crash_me10 (OVER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_pctfree=no # Keyword PCTFREE + ###< create table crash_me10 (PCTFREE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_percent=no # Keyword PERCENT + ###< create table crash_me10 (PERCENT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_plan=no # Keyword PLAN + ###< create table crash_me10 (PLAN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_print=no # Keyword PRINT + ###< create table crash_me10 (PRINT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_proc=no # Keyword PROC + ###< create table crash_me10 (PROC int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_purge=yes # Keyword PURGE + ###< create table crash_me10 (PURGE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PURGE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_raiserror=no # Keyword RAISERROR + ###< create table crash_me10 (RAISERROR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_raw=no # Keyword RAW + ###< create table crash_me10 (RAW int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_readtext=no # Keyword READTEXT + ###< create table crash_me10 (READTEXT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_reconfigure=no # Keyword RECONFIGURE + ###< create table crash_me10 (RECONFIGURE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_regexp=yes # Keyword REGEXP + ###< create table crash_me10 (REGEXP int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REGEXP int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_rename=yes # Keyword RENAME + ###< create table crash_me10 (RENAME int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'RENAME int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_replication=no # Keyword REPLICATION + ###< create table crash_me10 (REPLICATION int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_require=yes # Keyword REQUIRE + ###< create table crash_me10 (REQUIRE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'REQUIRE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_resource=no # Keyword RESOURCE + ###< create table crash_me10 (RESOURCE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_restore=no # Keyword RESTORE + ###< create table crash_me10 (RESTORE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rlike=yes # Keyword RLIKE + ###< create table crash_me10 (RLIKE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'RLIKE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_rowcount=no # Keyword ROWCOUNT + ###< create table crash_me10 (ROWCOUNT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rowguidcol=no # Keyword ROWGUIDCOL + ###< create table crash_me10 (ROWGUIDCOL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rowid=no # Keyword ROWID + ###< create table crash_me10 (ROWID int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rownum=no # Keyword ROWNUM + ###< create table crash_me10 (ROWNUM int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rtree=no # Keyword RTREE + ###< create table crash_me10 (RTREE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_rule=no # Keyword RULE + ###< create table crash_me10 (RULE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_save=no # Keyword SAVE + ###< create table crash_me10 (SAVE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_setuser=no # Keyword SETUSER + ###< create table crash_me10 (SETUSER int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_share=no # Keyword SHARE + ###< create table crash_me10 (SHARE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_show=yes # Keyword SHOW + ###< create table crash_me10 (SHOW int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SHOW int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_shutdown=no # Keyword SHUTDOWN + ###< create table crash_me10 (SHUTDOWN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_soname=yes # Keyword SONAME + ###< create table crash_me10 (SONAME int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SONAME int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_spatial=no # Keyword SPATIAL + ###< create table crash_me10 (SPATIAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_sql_big_result=yes # Keyword SQL_BIG_RESULT + ###< create table crash_me10 (SQL_BIG_RESULT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SQL_BIG_RESULT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_sql_calc_found_rows=yes # Keyword SQL_CALC_FOUND_ROWS + ###< create table crash_me10 (SQL_CALC_FOUND_ROWS int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SQL_CALC_FOUND_ROWS int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_sql_small_result=yes # Keyword SQL_SMALL_RESULT + ###< create table crash_me10 (SQL_SMALL_RESULT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SQL_SMALL_RESULT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_ssl=yes # Keyword SSL + ###< create table crash_me10 (SSL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SSL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_starting=yes # Keyword STARTING + ###< create table crash_me10 (STARTING int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'STARTING int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_statistics=no # Keyword STATISTICS + ###< create table crash_me10 (STATISTICS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_straight_join=yes # Keyword STRAIGHT_JOIN + ###< create table crash_me10 (STRAIGHT_JOIN int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'STRAIGHT_JOIN int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_striped=no # Keyword STRIPED + ###< create table crash_me10 (STRIPED int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_successful=no # Keyword SUCCESSFUL + ###< create table crash_me10 (SUCCESSFUL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_synonym=no # Keyword SYNONYM + ###< create table crash_me10 (SYNONYM int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_sysdate=no # Keyword SYSDATE + ###< create table crash_me10 (SYSDATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_tables=yes # Keyword TABLES + ###< create table crash_me10 (TABLES int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TABLES int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_terminated=yes # Keyword TERMINATED + ###< create table crash_me10 (TERMINATED int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TERMINATED int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_textsize=no # Keyword TEXTSIZE + ###< create table crash_me10 (TEXTSIZE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_tinyblob=yes # Keyword TINYBLOB + ###< create table crash_me10 (TINYBLOB int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TINYBLOB int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_tinyint=yes # Keyword TINYINT + ###< create table crash_me10 (TINYINT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TINYINT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_tinytext=yes # Keyword TINYTEXT + ###< create table crash_me10 (TINYTEXT int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TINYTEXT int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_top=no # Keyword TOP + ###< create table crash_me10 (TOP int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_tran=no # Keyword TRAN + ###< create table crash_me10 (TRAN int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_truncate=no # Keyword TRUNCATE + ###< create table crash_me10 (TRUNCATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_tsequal=no # Keyword TSEQUAL + ###< create table crash_me10 (TSEQUAL int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_types=no # Keyword TYPES + ###< create table crash_me10 (TYPES int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_uid=no # Keyword UID + ###< create table crash_me10 (UID int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_unlock=yes # Keyword UNLOCK + ###< create table crash_me10 (UNLOCK int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'UNLOCK int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_unsigned=yes # Keyword UNSIGNED + ###< create table crash_me10 (UNSIGNED int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'UNSIGNED int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_updatetext=no # Keyword UPDATETEXT + ###< create table crash_me10 (UPDATETEXT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_use=yes # Keyword USE + ###< create table crash_me10 (USE int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'USE int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_user_resources=no # Keyword USER_RESOURCES + ###< create table crash_me10 (USER_RESOURCES int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_validate=no # Keyword VALIDATE + ###< create table crash_me10 (VALIDATE int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_varbinary=yes # Keyword VARBINARY + ###< create table crash_me10 (VARBINARY int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'VARBINARY int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_varchar2=no # Keyword VARCHAR2 + ###< create table crash_me10 (VARCHAR2 int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_waitfor=no # Keyword WAITFOR + ###< create table crash_me10 (WAITFOR int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_warnings=no # Keyword WARNINGS + ###< create table crash_me10 (WARNINGS int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_writetext=no # Keyword WRITETEXT + ###< create table crash_me10 (WRITETEXT int not null) + ###> OK + ###< drop table crash_me10 + ###> OK + ### + ###As far as all queries returned OK, result is NO +reserved_word_extra_xor=yes # Keyword XOR + ###< create table crash_me10 (XOR int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'XOR int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_year_month=yes # Keyword YEAR_MONTH + ###< create table crash_me10 (YEAR_MONTH int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'YEAR_MONTH int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +reserved_word_extra_zerofill=yes # Keyword ZEROFILL + ###< create table crash_me10 (ZEROFILL int not null) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'ZEROFILL int not null)' at line 1 + ###< drop table crash_me10 + ###> execute error:Unknown table 'crash_me10' + ### + ###As far as some queries didnt return OK, result is YES +right_outer_join=yes # right outer join + ###< select crash_me.a from crash_me right join crash_me2 ON crash_me.a=crash_me2.a + ###> OK + ### + ###As far as all queries returned OK, result is YES +rollback_metadata=no # rollback_metadata + ###< create table crash_q (a integer not null) + ###> OK + ### + ###< insert into crash_q values (1) + ###> OK +rowid=auto_increment # Type for row id + ###< create table crash_q (a rowid) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'rowid)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###< create table crash_q (a int not null auto_increment, primary key(a)) + ###> OK + ###< drop table crash_q + ###> OK +safe_decimal_arithmetic=no # safe decimal arithmetic + ###< create table crash_me_a (a decimal(10,2),b decimal(10,2)) + ###> OK + ### + ###< insert into crash_me_a (a,b) values (11.4,18.9) + ###> OK + ### + ###<select count(*) from crash_me_a where a+b=30.3 + ###>0 + ###We expected '1' but got '0' +select_constants=yes # Select constants + ###< select 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +select_limit=with LIMIT # LIMIT number of rows + ###< select * from crash_me limit 1 + ###> OK +select_limit2=yes # SELECT with LIMIT #,# + ###< select * from crash_me limit 1,1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +select_limit3=yes # SELECT with LIMIT # OFFSET # + ###< select * from crash_me limit 1 offset 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +select_string_size=1048565 # constant string size in SELECT + ###We are trying (example with N=5): + ###select 'aaaaa' +select_table_update=no # Update with sub select + ###< create table crash_q (a integer,b char(10)) + ###> OK + ###< insert into crash_q values(1,'c') + ###> OK + ###< update crash_q set b= (select b from crash_me where crash_q.a = crash_me.a) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select b from crash_me where crash_q.a = crash_me.a)' at line 1 + ### + ###< drop table crash_q + ###> OK +select_without_from=yes # SELECT without FROM + ###< select 1 + ###> OK + ### + ###As far as all queries returned OK, result is YES +server_version=MySQL 4.0.15 debug log/ # server version +simple_joins=yes # ANSI SQL simple joins + ###< select crash_me.a from crash_me, crash_me t0 + ###> OK + ### + ###As far as all queries returned OK, result is YES +sorted_group_by=yes # Group by always sorted + ###< create table crash_me_t1 (a int not null, b int not null) + ###> OK + ###< insert into crash_me_t1 values (1,1) + ###> OK + ###< insert into crash_me_t1 values (1,2) + ###> OK + ###< insert into crash_me_t1 values (3,1) + ###> OK + ###< insert into crash_me_t1 values (3,2) + ###> OK + ###< insert into crash_me_t1 values (2,2) + ###> OK + ###< insert into crash_me_t1 values (2,1) + ###> OK + ###< create table crash_me_t2 (a int not null, b int not null) + ###> OK + ###< create index crash_me_t2_ind on crash_me_t2 (a) + ###> OK + ###< insert into crash_me_t2 values (1,3) + ###> OK + ###< insert into crash_me_t2 values (3,1) + ###> OK + ###< insert into crash_me_t2 values (2,2) + ###> OK + ###< insert into crash_me_t2 values (1,1) + ###> OK + ### + ###< select crash_me_t1.a,crash_me_t2.b from crash_me_t1,crash_me_t2 where crash_me_t1.a=crash_me_t2.a group by crash_me_t1.a,crash_me_t2.b + ### > 1,1 + ### > 1,3 + ### > 2,2 + ### > 3,1 + ### + ### Check recordset: + ### 1,1 expected: 1,1 + ### 1,3 expected: 1,3 + ### 2,2 expected: 2,2 + ### 3,1 expected: 3,1 + ### Recordset corresponds with template + ###< drop table crash_me_t1 + ###> OK + ###< drop table crash_me_t2 + ###> OK +storage_of_float=round # Storage of float values + ###< create table crash_q (q1 float(4,1)) + ###> OK + ###< insert into crash_q values(1.14) + ###> OK + ### + ###<select q1 from crash_q + ###>1.1 + ### + ###< drop table crash_q + ###> OK + ### + ###< create table crash_q (q1 float(4,1)) + ###> OK + ###< insert into crash_q values(1.16) + ###> OK + ### + ###<select q1 from crash_q + ###>1.2 + ###We expected '1.1' but got '1.2' + ### + ###< drop table crash_q + ###> OK + ### + ###< create table crash_q (q1 float(4,1)) + ###> OK + ###< insert into crash_q values(1.14) + ###> OK + ### + ###<select q1 from crash_q + ###>1.1 + ### + ###< drop table crash_q + ###> OK + ### + ###< create table crash_q (q1 float(4,1)) + ###> OK + ###< insert into crash_q values(1.16) + ###> OK + ### + ###<select q1 from crash_q + ###>1.2 + ### + ###< drop table crash_q + ###> OK +subqueries=no # subqueries + ###< select a from crash_me where crash_me.a in (select max(a) from crash_me) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select max(a) from crash_me)' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +table_alias=yes # Table alias + ###< select b.a from crash_me as b + ###> OK + ### + ###As far as all queries returned OK, result is YES +table_name_case=no # case independent table names + ###< create table crash_q (q integer) + ###> OK + ###< drop table CRASH_Q + ###> execute error:Unknown table 'CRASH_Q' + ### + ###As far as some queries didnt return OK, result is NO +table_wildcard=yes # Select table_name.* + ###< select crash_me.* from crash_me + ###> OK + ### + ###As far as all queries returned OK, result is YES +temporary_table=yes # temporary tables + ###< create temporary table crash_q (q integer not null) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +time_format_EUR=error # Supports HH.MM.SS (EUR) time format + ###< insert into crash_me_t(a) values ('20.08.16') + ###> OK + ### + ###<select a from crash_me_t + ###>00:00:20 + ###We expected '20:08:16' but got '00:00:20' + ### + ###< delete from crash_me_t + ###> OK +time_format_HHHHMMSS=yes # Supports HHHHmmSS time format + ###< insert into crash_me_t(a) values ('00200816') + ###> OK + ### + ###<select a from crash_me_t + ###>20:08:16 + ### + ###< delete from crash_me_t + ###> OK +time_format_ISO=yes # Supports HH:MM:SS (ISO) time format + ###< insert into crash_me_t(a) values ('20:08:16') + ###> OK + ### + ###<select a from crash_me_t + ###>20:08:16 + ### + ###< delete from crash_me_t + ###> OK +time_format_USA=error # Supports HH:MM:SS (AM|PM) time format + ###< insert into crash_me_t(a) values ('08:08:16 PM') + ###> OK + ### + ###<select a from crash_me_t + ###>08:08:16 + ###We expected '20:08:16' but got '08:08:16' + ### + ###< delete from crash_me_t + ###> OK +time_format_inresult=iso # Time format in result + ###< insert into crash_me_t values(CURRENT_TIME) + ###> OK + ### + ###< select a from crash_me_t + ###> 19:55:21 + ###< delete from crash_me_t + ###> OK +transactions=yes # transactions + ###<select * from crash_q + ###>1 + ###We expected '' but got '1' +truncate_table=yes # truncate + ###< create table crash_q (a integer, b integer,c1 CHAR(10)) + ###> OK + ###< truncate table crash_q + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_abstime=no # Type abstime + ###< create table crash_q (q abstime) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'abstime)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_bfile=no # Type bfile + ###< create table crash_q (q bfile) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'bfile)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_blob=yes # Type blob + ###< create table crash_q (q blob) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_bool=yes # Type bool + ###< create table crash_q (q bool) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_box=no # Type box + ###< create table crash_q (q box) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'box)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_byte=no # Type byte + ###< create table crash_q (q byte) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'byte)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_char(1_arg)_binary=yes # Type char(1 arg) binary + ###< create table crash_q (q char(10) binary) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_cidr=no # Type cidr + ###< create table crash_q (q cidr) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'cidr)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_circle=no # Type circle + ###< create table crash_q (q circle) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'circle)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_clob=no # Type clob + ###< create table crash_q (q clob) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'clob)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_datetime=yes # Type datetime + ###< create table crash_q (q datetime) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_double=yes # Type double + ###< create table crash_q (q double) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_enum(1_arg)=yes # Type enum(1 arg) + ###< create table crash_q (q enum('red')) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_float(2_arg)=yes # Type float(2 arg) + ###< create table crash_q (q float(6,2)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_float4=yes # Type float4 + ###< create table crash_q (q float4) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_float8=yes # Type float8 + ###< create table crash_q (q float8) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_image=no # Type image + ###< create table crash_q (q image) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'image)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_inet=no # Type inet + ###< create table crash_q (q inet) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'inet)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_int(1_arg)_zerofill=yes # Type int(1 arg) zerofill + ###< create table crash_q (q int(5) zerofill) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int1=yes # Type int1 + ###< create table crash_q (q int1) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int2=yes # Type int2 + ###< create table crash_q (q int2) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int3=yes # Type int3 + ###< create table crash_q (q int3) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int4=yes # Type int4 + ###< create table crash_q (q int4) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int8=yes # Type int8 + ###< create table crash_q (q int8) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int_auto_increment=yes # Type int not null auto_increment + ###< create table crash_q (q int not null auto_increment,unique(q)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_int_identity=no # Type int not null identity + ###< create table crash_q (q int not null identity,unique(q)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'identity,unique(q))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_int_unsigned=yes # Type int unsigned + ###< create table crash_q (q int unsigned) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_interval=no # Type interval + ###< create table crash_q (q interval) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_line=no # Type line + ###< create table crash_q (q line) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'line)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_long=no # Type long + ###< create table crash_q (q long) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_long_raw=no # Type long raw + ###< create table crash_q (q long raw) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'raw)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_long_varbinary=yes # Type long varbinary + ###< create table crash_q (q long varbinary) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_long_varchar(1_arg)=no # Type long varchar(1 arg) + ###< create table crash_q (q long varchar(1)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_lseg=no # Type lseg + ###< create table crash_q (q lseg) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'lseg)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_macaddr=no # Type macaddr + ###< create table crash_q (q macaddr) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'macaddr)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_mediumint=yes # Type mediumint + ###< create table crash_q (q mediumint) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_mediumtext=yes # Type mediumtext + ###< create table crash_q (q mediumtext) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_middleint=yes # Type middleint + ###< create table crash_q (q middleint) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_mlslabel=no # Type mlslabel + ###< create table crash_q (q mlslabel) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'mlslabel)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_money=no # Type money + ###< create table crash_q (q money) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'money)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_nclob=no # Type nclob + ###< create table crash_q (q nclob) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'nclob)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_number=no # Type number + ###< create table crash_q (q number) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'number)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_number(1_arg)=no # Type number(1 arg) + ###< create table crash_q (q number(9)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'number(9))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_number(2_arg)=no # Type number(2 arg) + ###< create table crash_q (q number(9,2)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'number(9,2))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_nvarchar2(1_arg)=no # Type nvarchar2(1 arg) + ###< create table crash_q (q nvarchar2(16)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'nvarchar2(16))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_path=no # Type path + ###< create table crash_q (q path) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'path)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_point=no # Type point + ###< create table crash_q (q point) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'point)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_polygon=no # Type polygon + ###< create table crash_q (q polygon) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'polygon)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_raw(1_arg)=no # Type raw(1 arg) + ###< create table crash_q (q raw(16)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'raw(16))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_reltime=no # Type reltime + ###< create table crash_q (q reltime) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'reltime)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_rowid=no # Type rowid + ###< create table crash_q (q rowid) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'rowid)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_serial=no # Type serial + ###< create table crash_q (q serial) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'serial)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_set(1_arg)=yes # Type set(1 arg) + ###< create table crash_q (q set('red')) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_smalldatetime=no # Type smalldatetime + ###< create table crash_q (q smalldatetime) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'smalldatetime)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_smallfloat=no # Type smallfloat + ###< create table crash_q (q smallfloat) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'smallfloat)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_smallmoney=no # Type smallmoney + ###< create table crash_q (q smallmoney) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'smallmoney)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_text=yes # Type text + ###< create table crash_q (q text) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_extra_text(1_arg)=no # Type text(1 arg) + ###< create table crash_q (q text(10)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(10))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_timespan=no # Type timespan + ###< create table crash_q (q timespan) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'timespan)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_uint=no # Type uint + ###< create table crash_q (q uint) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'uint)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_varchar2(1_arg)=no # Type varchar2(1 arg) + ###< create table crash_q (q varchar2(257)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'varchar2(257))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_extra_year=yes # Type year + ###< create table crash_q (q year) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_odbc_bigint=yes # Type bigint + ###< create table crash_q (q bigint) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_odbc_binary(1_arg)=yes # Type binary(1 arg) + ###< create table crash_q (q binary(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_odbc_datetime=yes # Type datetime + ###< create table crash_q (q datetime) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_odbc_tinyint=yes # Type tinyint + ###< create table crash_q (q tinyint) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_odbc_varbinary(1_arg)=yes # Type varbinary(1 arg) + ###< create table crash_q (q varbinary(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_bit=yes # Type bit + ###< create table crash_q (q bit) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_bit(1_arg)=yes # Type bit(1 arg) + ###< create table crash_q (q bit(2)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_bit_varying(1_arg)=no # Type bit varying(1 arg) + ###< create table crash_q (q bit varying(2)) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'varying(2))' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_boolean=no # Type boolean + ###< create table crash_q (q boolean) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'boolean)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_char(1_arg)=yes # Type char(1 arg) + ###< create table crash_q (q char(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_char_varying(1_arg)=yes # Type char varying(1 arg) + ###< create table crash_q (q char varying(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_character(1_arg)=yes # Type character(1 arg) + ###< create table crash_q (q character(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_character_varying(1_arg)=yes # Type character varying(1 arg) + ###< create table crash_q (q character varying(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_date=yes # Type date + ###< create table crash_q (q date) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_dec(2_arg)=yes # Type dec(2 arg) + ###< create table crash_q (q dec(6,2)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_decimal(2_arg)=yes # Type decimal(2 arg) + ###< create table crash_q (q decimal(6,2)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_double_precision=yes # Type double precision + ###< create table crash_q (q double precision) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_float=yes # Type float + ###< create table crash_q (q float) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_float(1_arg)=yes # Type float(1 arg) + ###< create table crash_q (q float(8)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_int=yes # Type int + ###< create table crash_q (q int) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_integer=yes # Type integer + ###< create table crash_q (q integer) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_interval_day=no # Type interval day + ###< create table crash_q (q interval day) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval day)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_day_to_hour=no # Type interval day to hour + ###< create table crash_q (q interval day to hour) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval day to hour)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_day_to_minute=no # Type interval day to minute + ###< create table crash_q (q interval day to minute) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval day to minute)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_day_to_second=no # Type interval day to second + ###< create table crash_q (q interval day to second) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval day to second)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_hour=no # Type interval hour + ###< create table crash_q (q interval hour) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval hour)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_hour_to_minute=no # Type interval hour to minute + ###< create table crash_q (q interval hour to minute) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval hour to minute)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_hour_to_second=no # Type interval hour to second + ###< create table crash_q (q interval hour to second) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval hour to second)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_minute=no # Type interval minute + ###< create table crash_q (q interval minute) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval minute)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_minute_to_second=no # Type interval minute to second + ###< create table crash_q (q interval minute to second) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval minute to second)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_month=no # Type interval month + ###< create table crash_q (q interval month) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval month)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_second=no # Type interval second + ###< create table crash_q (q interval second) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval second)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_year=no # Type interval year + ###< create table crash_q (q interval year) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval year)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_interval_year_to_month=no # Type interval year to month + ###< create table crash_q (q interval year to month) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'interval year to month)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_national_char_varying(1_arg)=yes # Type national char varying(1 arg) + ###< create table crash_q (q national char varying(20)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_national_character(1_arg)=yes # Type national character(1 arg) + ###< create table crash_q (q national character(20)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_national_character_varying(1_arg)=yes # Type national character varying(1 arg) + ###< create table crash_q (q national character varying(20)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_nchar(1_arg)=yes # Type nchar(1 arg) + ###< create table crash_q (q nchar(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_nchar_varying(1_arg)=yes # Type nchar varying(1 arg) + ###< create table crash_q (q nchar varying(20)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_numeric(2_arg)=yes # Type numeric(2 arg) + ###< create table crash_q (q numeric(9,2)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_real=yes # Type real + ###< create table crash_q (q real) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_smallint=yes # Type smallint + ###< create table crash_q (q smallint) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_time=yes # Type time + ###< create table crash_q (q time) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_timestamp=yes # Type timestamp + ###< create table crash_q (q timestamp) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +type_sql_timestamp_with_time_zone=no # Type timestamp with time zone + ###< create table crash_q (q timestamp with time zone) + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'with time zone)' at line 1 + ###< drop table crash_q + ###> execute error:Unknown table 'crash_q' + ### + ###As far as some queries didnt return OK, result is NO +type_sql_varchar(1_arg)=yes # Type varchar(1 arg) + ###< create table crash_q (q varchar(1)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +union=yes # union + ###< select * from crash_me union select a,b from crash_me3 + ###> OK + ### + ###As far as all queries returned OK, result is YES +union_all=yes # union all + ###< select * from crash_me union all select a,b from crash_me3 + ###> OK + ### + ###As far as all queries returned OK, result is YES +union_all_incompat=yes # union all (incompatible lists) + ###< select * from crash_me union all select a,b from crash_me2 + ###> OK + ### + ###As far as all queries returned OK, result is YES +union_incompat=yes # union (incompatible lists) + ###< select * from crash_me union select a,b from crash_me2 + ###> OK + ### + ###As far as all queries returned OK, result is YES +unique_in_create=yes # unique in create table + ###< create table crash_q (q integer not null,unique (q)) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +unique_null_in_create=yes # unique null in create + ###< create table crash_q (q integer,unique (q)) + ###> OK + ###< insert into crash_q (q) values (NULL) + ###> OK + ###< insert into crash_q (q) values (NULL) + ###> OK + ###< insert into crash_q (q) values (1) + ###> OK + ###< drop table crash_q + ###> OK + ### + ###As far as all queries returned OK, result is YES +value_of_false=not supported # Value of FALSE + ###<select FALSE + ###> execute failed:Unknown column 'FALSE' in 'field list' +value_of_true=not supported # Value of TRUE + ###<select TRUE + ###> execute failed:Unknown column 'TRUE' in 'field list' +views=no # views + ###< create view crash_q as select a from crash_me + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'view crash_q as select a from crash_me' at line 1 + ###< drop view crash_q + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'view crash_q' at line 1 + ### + ###As far as some queries didnt return OK, result is NO +where_string_size=1048539 # constant string size in where + ###We are trying (example with N=5): + ###select a from crash_me where b >='11111' diff --git a/sql-bench/limits/mysql.cfg b/sql-bench/limits/mysql.cfg index feaa79e43e9..64f91f07363 100644 --- a/sql-bench/limits/mysql.cfg +++ b/sql-bench/limits/mysql.cfg @@ -82,7 +82,7 @@ alter_drop_unique=with drop key # Alter table drop unique ###< alter table crash_q drop constraint u1 restrict ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'constraint u1 restrict' at line 1 ### - ###< alter table crash_q drop key c1 + ###< alter table crash_q drop key u1 ###> OK alter_modify_col=yes # Alter table modify column ###< alter table crash_q modify c1 CHAR(20) @@ -345,7 +345,7 @@ date_format_inresult=iso # Date format in result ###> OK ### ###< select a from crash_me_d - ###> 2003-08-27 + ###> 2004-04-06 ###< delete from crash_me_d ###> OK date_infinity=error # Supports 'infinity dates @@ -558,14 +558,14 @@ func_extra_add_months=no # Function ADD_MONTHS ### ###<select add_months('1997-01-01',1) from crash_me_d ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1997-01-01',1) from crash_me_d' at line 1 -func_extra_adddate=no # Function ADDDATE +func_extra_adddate=yes # Function ADDDATE ### ###<select ADDDATE('2002-12-01',3) from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '3) from crash_me_d' at line 1 -func_extra_addtime=no # Function ADDTIME + ###>2002-12-04 +func_extra_addtime=yes # Function ADDTIME ### ###<select ADDTIME('20:02:12','00:00:03') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:12','00:00:03')' at line 1 + ###>20:02:15 func_extra_alpha=no # Function ALPHA ### ###<select alpha('Aâ',2) @@ -648,10 +648,10 @@ func_extra_cosh=no # Function COSH ### ###<select cosh(0) ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(0)' at line 1 -func_extra_date=no # Function DATE +func_extra_date=yes # Function DATE ### ###<select date('1963-08-16') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1963-08-16') from crash_me_d' at line 1 + ###>1963-08-16 func_extra_date_format=yes # Function DATE_FORMAT ### ###<select date_format('1997-01-02 03:04:05','M W D Y y m d h i s w') from crash_me_d @@ -663,11 +663,11 @@ func_extra_dateadd=no # Function DATEADD func_extra_datediff=no # Function DATEDIFF ### ###<select datediff(month,'Oct 21 1997','Nov 30 1997') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(month,'Oct 21 1997','Nov 30 1997') from crash_me_d' at line 1 -func_extra_datediff2arg=no # Function DATEDIFF (2 arg) + ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ''Nov 30 1997') from crash_me_d' at line 1 +func_extra_datediff2arg=yes # Function DATEDIFF (2 arg) ### ###<select DATEDIFF('2002-12-04','2002-12-01') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('2002-12-04','2002-12-01') from crash_me_d' at line 1 + ###>3 func_extra_datename=no # Function DATENAME ### ###<select datename(month,'Nov 30 1997') from crash_me_d @@ -676,10 +676,10 @@ func_extra_datepart=no # Function DATEPART ### ###<select datepart(month,'July 20 1997') from crash_me_d ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(month,'July 20 1997') from crash_me_d' at line 1 -func_extra_day=no # Function DAY +func_extra_day=yes # Function DAY ### ###<select DAY('2002-12-01') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('2002-12-01') from crash_me_d' at line 1 + ###>1 func_extra_decode=no # Function DECODE ### ###<select DECODE('S-103','T72',1,'S-103',2,'Leopard',3) @@ -695,7 +695,7 @@ func_extra_elt=yes # Function ELT func_extra_encrypt=yes # Function ENCRYPT ### ###<select encrypt('hello') - ###>tHrzZO8Aq1FG6 + ###>VNeu3dE4DbVJY func_extra_expand2arg=no # Function EXPAND ### ###<select expand('abcd',6) @@ -772,10 +772,10 @@ func_extra_interval=yes # Function INTERVAL ### ###<select interval(55,10,20,30,40,50,60,70,80,90,100) ###>5 -func_extra_last_day=no # Function LAST_DAY +func_extra_last_day=yes # Function LAST_DAY ### ###<select last_day('1997-04-01') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1997-04-01') from crash_me_d' at line 1 + ###>1997-04-30 func_extra_last_insert_id=yes # Function LAST_INSERT_ID ### ###<select last_insert_id() @@ -825,14 +825,14 @@ func_extra_ltrim2arg=no # Function LTRIM (2 arg) ### ###<select ltrim('..abcd..','.') ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ''.')' at line 1 -func_extra_makedate=no # Function MAKEDATE +func_extra_makedate=yes # Function MAKEDATE ### ###<select MAKEDATE(1963,228) from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1963,228) from crash_me_d' at line 1 -func_extra_maketime=no # Function MAKETIME + ###>1963-08-16 +func_extra_maketime=yes # Function MAKETIME ### ###<select MAKETIME(20,02,12) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(20,02,12)' at line 1 + ###>20:02:12 func_extra_mapchar=no # Function MAPCHAR ### ###<select mapchar('Aâ') @@ -841,10 +841,10 @@ func_extra_mdy=no # Function MDY ### ###<select mdy(7,1,1998) from crash_me_d ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(7,1,1998) from crash_me_d' at line 1 -func_extra_microsecond=no # Function MICROSECOND +func_extra_microsecond=yes # Function MICROSECOND ### ###<select MICROSECOND('19630816200212111111') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('19630816200212111111')' at line 1 + ###>110000 func_extra_mid=yes # Function SUBSTRING as MID ### ###<select mid('hello',3,2) @@ -858,7 +858,7 @@ func_extra_noround=no # Function NOROUND ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(22.6)' at line 1 func_extra_not=yes # Function NOT in SELECT ### - ###<select not 0 + ###<select not false ###>1 func_extra_not_between=yes # Function NOT BETWEEN in SELECT ### @@ -879,7 +879,7 @@ func_extra_odbc_convert=no # Function ODBC CONVERT func_extra_password=yes # Function PASSWORD ### ###<select password('hello') - ###>70de51425df9d787 + ###>*6B4F89A54E2D27ECD7E8DA05B4AB8FD9D1D8B119 func_extra_paste=no # Function PASTE ### ###<select paste('ABCDEFG',3,2,'1234') @@ -964,18 +964,18 @@ func_extra_stuff=no # Function STUFF ### ###<select stuff('abc',2,3,'xyz') ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abc',2,3,'xyz')' at line 1 -func_extra_subdate=no # Function SUBDATE +func_extra_subdate=yes # Function SUBDATE ### ###<select SUBDATE('2002-12-04',3) from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '3) from crash_me_d' at line 1 -func_extra_substr2arg=no # Function SUBSTR (2 arg) + ###>2002-12-01 +func_extra_substr2arg=yes # Function SUBSTR (2 arg) ### ###<select substr('abcd',2) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd',2)' at line 1 -func_extra_substr3arg=no # Function SUBSTR (3 arg) + ###>bcd +func_extra_substr3arg=yes # Function SUBSTR (3 arg) ### ###<select substr('abcd',2,2) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('abcd',2,2)' at line 1 + ###>bc func_extra_substrb=no # Function SUBSTRB ### ###<select SUBSTRB('ABCDEFG',5,4.2) @@ -984,14 +984,14 @@ func_extra_substring_index=yes # Function SUBSTRING_INDEX ### ###<select substring_index('www.tcx.se','.',-2) ###>tcx.se -func_extra_subtime=no # Function SUBTIME +func_extra_subtime=yes # Function SUBTIME ### ###<select SUBTIME('20:02:15','00:00:03') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:15','00:00:03')' at line 1 + ###>20:02:12 func_extra_sysdate=yes # Function SYSDATE ### ###<select sysdate() - ###>2003-08-27 19:55:21 + ###>2004-04-06 13:49:05 func_extra_tail=no # Function TAIL ### ###<select tail('ABCDEFG',3) @@ -1000,22 +1000,23 @@ func_extra_tanh=no # Function TANH ### ###<select tanh(1) ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(1)' at line 1 -func_extra_time=no # Function TIME +func_extra_time=yes # Function TIME ### ###<select time('20:02:12') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:12')' at line 1 + ###>20:02:12 func_extra_time_to_sec=yes # Function TIME_TO_SEC ### ###<select time_to_sec('01:23:21') ###>5001 -func_extra_timediff=no # Function TIMEDIFF +func_extra_timediff=yes # Function TIMEDIFF ### ###<select TIMEDIFF('20:02:15','20:02:12') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('20:02:15','20:02:12')' at line 1 -func_extra_timestamp=no # Function TIMESTAMP + ###>00:00:03 +func_extra_timestamp=error # Function TIMESTAMP ### ###<select timestamp('19630816','00200212') - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('19630816','00200212')' at line 1 + ###>1963-08-16 20:02:12 + ###We expected '19630816200212000000' but got '1963-08-16 20:02:12' func_extra_to_days=yes # Function TO_DAYS ### ###<select to_days('1996-01-01') from crash_me_d @@ -1056,7 +1057,7 @@ func_extra_uid=no # Function UID func_extra_unix_timestamp=yes # Function UNIX_TIMESTAMP ### ###<select unix_timestamp() - ###>1062003321 + ###>1081248545 func_extra_userenv=no # Function USERENV ### ###<select userenv @@ -1068,15 +1069,15 @@ func_extra_value=no # Function VALUE func_extra_version=yes # Function VERSION ### ###<select version() - ###>4.0.15-debug-log + ###>4.1.2-alpha func_extra_weekday=yes # Function WEEKDAY ### ###<select weekday('1997-11-29') from crash_me_d ###>5 -func_extra_weekofyear=no # Function WEEKOFYEAR +func_extra_weekofyear=yes # Function WEEKOFYEAR ### ###<select WEEKOFYEAR('1963-08-16') from crash_me_d - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '('1963-08-16') from crash_me_d' at line 1 + ###>33 func_extra_|=yes # Function | (bitwise or) ### ###<select 1 | 2 @@ -1136,11 +1137,11 @@ func_odbc_cot=yes # Function COT func_odbc_curdate=yes # Function CURDATE ### ###<select curdate() - ###>2003-08-27 + ###>2004-04-06 func_odbc_curtime=yes # Function CURTIME ### ###<select curtime() - ###>19:55:21 + ###>13:49:04 func_odbc_database=yes # Function DATABASE ### ###<select database() @@ -1269,7 +1270,7 @@ func_odbc_monthname=yes # Function MONTHNAME func_odbc_now=yes # Function NOW ### ###<select now() - ###>2003-08-27 19:55:21 + ###>2004-04-06 13:49:04 func_odbc_pi=yes # Function PI ### ###<select pi() @@ -1416,20 +1417,17 @@ func_sql_concat_as_||=error # Function concatenation with || func_sql_current_date=yes # Function CURRENT_DATE ### ###<select current_date - ###>2003-08-27 + ###>2004-04-06 func_sql_current_time=yes # Function CURRENT_TIME ### ###<select current_time - ###>19:55:21 + ###>13:49:04 func_sql_current_timestamp=yes # Function CURRENT_TIMESTAMP ### ###<select current_timestamp - ###>2003-08-27 19:55:21 -func_sql_current_user=with_parenthesis # CURRENT_USER + ###>2004-04-06 13:49:04 +func_sql_current_user=yes # CURRENT_USER ###< select CURRENT_USER - ###> execute error:Unknown column 'CURRENT_USER' in 'field list' - ### - ###< select CURRENT_USER() ###> OK func_sql_extract_sql=yes # Function EXTRACT ### @@ -1438,11 +1436,11 @@ func_sql_extract_sql=yes # Function EXTRACT func_sql_localtime=yes # Function LOCALTIME ### ###<select localtime - ###>2003-08-27 19:55:21 + ###>2004-04-06 13:49:04 func_sql_localtimestamp=yes # Function LOCALTIMESTAMP ### ###<select localtimestamp - ###>2003-08-27 19:55:21 + ###>2004-04-06 13:49:04 func_sql_lower=yes # Function LOWER ### ###<select LOWER('ABC') @@ -1505,22 +1503,22 @@ func_where_between=yes # Function BETWEEN ### ###<select a from crash_me where 5 between 4 and 6 ###>1 -func_where_eq_all=no # Function = ALL +func_where_eq_all=yes # Function = ALL ### ###<select a from crash_me where b =all (select b from crash_me) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'all (select b from crash_me)' at line 1 -func_where_eq_any=no # Function = ANY + ###>1 +func_where_eq_any=yes # Function = ANY ### ###<select a from crash_me where b =any (select b from crash_me) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(select b from crash_me)' at line 1 -func_where_eq_some=no # Function = SOME + ###>1 +func_where_eq_some=yes # Function = SOME ### ###<select a from crash_me where b =some (select b from crash_me) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(select b from crash_me)' at line 1 -func_where_exists=no # Function EXISTS + ###>1 +func_where_exists=yes # Function EXISTS ### ###<select a from crash_me where exists (select * from crash_me) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'exists (select * from crash_me)' at line 1 + ###>1 func_where_in_num=yes # Function IN on numbers ### ###<select a from crash_me where 2 in (3,2,5,9,5,1) @@ -1549,10 +1547,10 @@ func_where_not_between=yes # Function NOT BETWEEN ### ###<select a from crash_me where 7 not between 4 and 6 ###>1 -func_where_not_exists=no # Function NOT EXISTS +func_where_not_exists=yes # Function NOT EXISTS ### ###<select a from crash_me where not exists (select * from crash_me where a = 2) - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'exists (select * from crash_me where a = 2)' at line 1 + ###>1 func_where_not_like=yes # Function NOT LIKE ### ###<select a from crash_me where b not like 'b%' @@ -1623,10 +1621,10 @@ group_func_extra_stddev=yes # Group function STDDEV ### ###<select stddev(a),a from crash_me group by a ###>0.0000 -group_func_extra_variance=no # Group function VARIANCE +group_func_extra_variance=yes # Group function VARIANCE ### ###<select variance(a),a from crash_me group by a - ###> execute failed:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(a),a from crash_me group by a' at line 1 + ###>0.0000 group_func_sql_any=no # Group function ANY ### ###<select any(a),a from crash_me group by a @@ -1690,9 +1688,9 @@ group_on_unused=yes # Group on unused column ###> OK ### ###As far as all queries returned OK, result is YES -has_true_false=no # TRUE and FALSE +has_true_false=yes # TRUE and FALSE ###< select (1=1)=true - ###> execute error:Unknown column 'true' in 'field list' + ###> OK having=yes # Having ###<select a from crash_me group by a having a > 0 ###>1 @@ -1832,10 +1830,10 @@ intersect_incompat=no # intersect (incompatible lists) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me2' at line 1 ### ###As far as some queries didnt return OK, result is NO -join_tables=31 # tables in join +join_tables=61 # tables in join ###We are trying (example with N=5): ###select crash_me.a,t0.a,t1.a,t2.a,t3.a,t4.a from crash_me,crash_me t0,crash_me t1,crash_me t2,crash_me t3,crash_me t4 - ### 32:FAIL 7:OK 19:OK 25:OK 28:OK 30:OK 31:FAIL + ### 32:OK 48:OK 56:OK 60:OK 62:FAIL 61:FAIL left_outer_join=yes # left outer join ###< select crash_me.a from crash_me left join crash_me2 ON crash_me.a=crash_me2.a ###> OK @@ -1890,39 +1888,39 @@ logical_value=1 # Value of logical operation (1=1) ###>1 max_big_expressions=10 # big expressions ###We are trying (example with N=5): - ###select 0+(1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+...(14308) + ###select 0+(1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+1+...(8168) ### 50:FAIL 10:OK 30:FAIL 14:FAIL 11:FAIL -max_char_size=255 # max char() size +max_char_size=1048543 # max char() size ###We are trying (example with N=5): ###create table crash_q (q char(5)) ###insert into crash_q values ('aaaaa') ###select * from crash_q - ### 524287:FAIL 104858:FAIL 20972:FAIL 4195:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK + ### 524287:OK 786431:OK 917503:OK 983039:OK 1015807:OK 1032191:OK 1040383:OK 1044479:OK 1046527:OK 1047551:OK 1048063:OK 1048319:OK 1048447:OK 1048511:OK 1048543:OK 1048559:FAIL 1048546:FAIL 1048544:FAIL max_column_name=64 # column name length ###We are trying (example with N=5): ###create table crash_q (qaaaaa integer) ###insert into crash_q (qaaaaa) values(1) ###select qaaaaa from crash_q ### 256:FAIL 51:OK 153:FAIL 72:FAIL 55:OK 63:OK 67:FAIL 64:FAIL -max_columns=3398 # Columns in table +max_columns=2599 # Columns in table ###We are trying (example with N=5): ###create table crash_q (a integer ,a0 integer,a1 integer,a2 integer,a3 integer,a4 integer) - ### 4096:FAIL 819:OK 2457:OK 3276:OK 3686:FAIL 3358:OK 3522:FAIL 3391:OK 3456:FAIL 3404:FAIL 3394:OK 3399:FAIL 3395:OK 3397:OK 3398:FAIL + ### 4096:FAIL 819:OK 2457:OK 3276:FAIL 2621:FAIL 2490:OK 2555:OK 2588:OK 2604:FAIL 2591:OK 2597:OK 2600:FAIL 2598:OK 2599:FAIL max_conditions=85660 # OR and AND in WHERE ###We are trying (example with N=5): ###select a from crash_me where a=1 and b='a' or a=0 and b='0' or a=1 and b='1' or a=2 and b='2' or a=3 and b='3' or a=4 and b='4' ### 27592:OK 41389:OK 48287:FAIL 42769:OK 45528:FAIL 43321:FAIL 42880:FAIL 42791:OK 42835:FAIL 42800:OK 42817:OK 42826:OK 42830:OK 42832:FAIL 42831:FAIL -max_expressions=1450 # simple expressions +max_expressions=836 # simple expressions ###We are trying (example with N=5): ###select 1+1+1+1+1+1 - ### 5000:FAIL 1000:OK 3000:FAIL 1400:OK 2200:FAIL 1560:FAIL 1432:OK 1496:FAIL 1445:OK 1470:FAIL 1450:OK 1460:FAIL 1452:FAIL 1451:FAIL + ### 5000:FAIL 1000:FAIL 200:OK 600:OK 800:OK 900:FAIL 820:OK 860:FAIL 828:OK 844:FAIL 831:OK 837:FAIL 832:OK 834:OK 835:OK 836:OK max_index=32 # max index ### max_unique_index=32 ,so max_index must be same -max_index_length=500 # index length +max_index_length=1000 # index length ###We are trying (example with N=5): ###create table crash_q (q0 char(5) not null,unique (q0)) ###insert into crash_q values('aaaaa') - ### 4096:FAIL 819:FAIL 164:OK 491:OK 655:FAIL 524:FAIL 498:OK 511:FAIL 501:FAIL 499:OK 500:OK + ### 4096:FAIL 819:OK 2457:FAIL 1147:FAIL 885:OK 1016:FAIL 911:OK 963:OK 989:OK 1002:FAIL 992:OK 997:OK 999:OK 1000:OK 1001:FAIL max_index_name=64 # index name length ###We are trying (example with N=5): ###create index crash_qaaaaa on crash_me (a) @@ -1932,6 +1930,7 @@ max_index_part_length=255 # max index part length ###create table crash_q (q char(5) not null,unique(q)) ###insert into crash_q (q) values ('aaaaa') ###select q from crash_q + ### 524271:FAIL 104854:FAIL 20971:FAIL 4194:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK max_index_parts=16 # index parts ###We are trying (example with N=5): ###create table crash_q (q0 integer not null,q1 integer not null,q2 integer not null,q3 integer not null,q4 integer not nul...(1263) @@ -1943,11 +1942,12 @@ max_index_varchar_part_length=255 # index varchar part length ###create table crash_q (q varchar(5) not null,unique(q)) ###insert into crash_q (q) values ('aaaaa') ###select q from crash_q + ### 524271:FAIL 104854:FAIL 20971:FAIL 4194:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK max_row_length=65534 # max table row length (without blobs) ###We are trying (example with N=5): ###create table crash_q (q0 char(5) not null) ###insert into crash_q values ('aaaaa') - ### 433245:FAIL 86649:FAIL 17330:OK 51989:OK 69319:FAIL 55455:OK 62387:OK 65853:FAIL 63080:OK 64466:OK 65159:OK 65506:OK 65679:FAIL 65541:FAIL 65513:OK 65527:OK 65534:OK 65537:FAIL 65535:FAIL + ### 331372:FAIL 66275:FAIL 13255:OK 39765:OK 53020:OK 59647:OK 62961:OK 64618:OK 65446:OK 65860:FAIL 65529:OK 65694:FAIL 65562:FAIL 65536:FAIL 65531:OK 65533:OK 65534:OK 65535:FAIL max_row_length_with_null=65502 # table row length with nulls (without blobs) ###We are trying (example with N=5): ###create table crash_q (q0 char(5) ) @@ -1956,10 +1956,10 @@ max_row_length_with_null=65502 # table row length with nulls (without blobs) max_select_alias_name=+512 # select alias name length ###We are trying (example with N=5): ###select b as aaaaa from crash_me -max_stack_expression=1450 # stacked expressions +max_stack_expression=836 # stacked expressions ###We are trying (example with N=5): ###select 1+(1+(1+(1+(1+(1))))) - ### 1000:OK 1500:FAIL 1100:OK 1300:OK 1400:OK 1450:OK 1475:FAIL 1455:FAIL 1451:FAIL + ### 1000:FAIL 200:OK 600:OK 800:OK 900:FAIL 820:OK 860:FAIL 828:OK 844:FAIL 831:OK 837:FAIL 832:OK 834:OK 835:OK 836:OK max_table_alias_name=+512 # table alias name length ###We are trying (example with N=5): ###select aaaaa.b from crash_me aaaaa @@ -1981,12 +1981,12 @@ max_unique_index=32 # unique indexes ###insert into crash_q (q,q1,q2,q3,q4,q5) values (1,1,1,1,1,1) ###select q from crash_q ### 32:OK 48:FAIL 35:FAIL 33:FAIL -max_varchar_size=255 # max varchar() size +max_varchar_size=1048543 # max varchar() size ###We are trying (example with N=5): ###create table crash_q (q varchar(5)) ###insert into crash_q values ('aaaaa') ###select * from crash_q - ### 524287:FAIL 104858:FAIL 20972:FAIL 4195:FAIL 839:FAIL 168:OK 503:FAIL 235:OK 369:FAIL 262:FAIL 241:OK 251:OK 256:FAIL 252:OK 254:OK 255:OK + ### 524287:OK 786431:OK 917503:OK 983039:OK 1015807:OK 1032191:OK 1040383:OK 1044479:OK 1046527:OK 1047551:OK 1048063:OK 1048319:OK 1048447:OK 1048511:OK 1048543:OK 1048559:FAIL 1048546:FAIL 1048544:FAIL minus=no # minus ###< select * from crash_me minus select * from crash_me3 ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select * from crash_me3' at line 1 @@ -2129,7 +2129,7 @@ odbc_left_outer_join=yes # left outer join odbc style ###> OK ### ###As far as all queries returned OK, result is YES -operating_system=Linux 2.4.20-64GB-SMP i686 # crash-me tested on +operating_system=Linux 2.4.21-199-smp4G i686 # crash-me tested on order_by=yes # Order by ###< select a from crash_me order by a ###> OK @@ -2267,6 +2267,9 @@ quote_with_"=yes # Allows ' and " as string markers ###> OK ### ###As far as all queries returned OK, result is YES +recursive_subqueries=+64 # recursive subqueries + ###We are trying (example with N=5): + ###select a from crash_me where a in (select a from crash_me where a in (select a from crash_me where a in (select a from c...(82) remember_end_space=no # Remembers end space in char() ###< create table crash_q (a char(10)) ###> OK @@ -2300,10 +2303,10 @@ rename_table=yes # rename table ###> OK ### ###As far as all queries returned OK, result is YES -repeat_string_size=1047552 # return string size from function +repeat_string_size=1048576 # return string size from function ###We are trying (example with N=5): ###select repeat('a',5) - ### 4000000:FAIL 800000:OK 2400000:FAIL 1120000:FAIL 864000:OK 992000:OK 1056000:FAIL 1004800:OK 1030400:OK 1043200:OK 1049600:FAIL 1044480:OK 1047040:OK 1048320:FAIL 1047296:OK 1047808:FAIL 1047399:OK 1047603:FAIL 1047440:OK 1047521:OK 1047562:FAIL 1047529:OK 1047545:OK 1047553:FAIL 1047547:OK 1047550:OK 1047551:OK 1047552:OK + ### 4000000:FAIL 800000:OK 2400000:FAIL 1120000:FAIL 864000:OK 992000:OK 1056000:FAIL 1004800:OK 1030400:OK 1043200:OK 1049600:FAIL 1044480:OK 1047040:OK 1048320:OK 1048960:FAIL 1048448:OK 1048704:FAIL 1048499:OK 1048601:FAIL 1048520:OK 1048560:OK 1048580:FAIL 1048564:OK 1048572:OK 1048576:OK 1048578:FAIL 1048577:FAIL reserved_word_ansi-92/99_absolute=no # Keyword ABSOLUTE ###< create table crash_me10 (ABSOLUTE int not null) ###> OK @@ -2416,13 +2419,13 @@ reserved_word_ansi-92/99_authorization=no # Keyword AUTHORIZATION ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi-92/99_before=no # Keyword BEFORE +reserved_word_ansi-92/99_before=yes # Keyword BEFORE ###< create table crash_me10 (BEFORE int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'BEFORE int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_ansi-92/99_begin=no # Keyword BEGIN ###< create table crash_me10 (BEGIN int not null) ###> OK @@ -2535,13 +2538,13 @@ reserved_word_ansi-92/99_close=no # Keyword CLOSE ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi-92/99_collate=no # Keyword COLLATE +reserved_word_ansi-92/99_collate=yes # Keyword COLLATE ###< create table crash_me10 (COLLATE int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'COLLATE int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_ansi-92/99_collation=no # Keyword COLLATION ###< create table crash_me10 (COLLATION int not null) ###> OK @@ -2913,13 +2916,13 @@ reserved_word_ansi-92/99_external=no # Keyword EXTERNAL ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi-92/99_false=no # Keyword FALSE +reserved_word_ansi-92/99_false=yes # Keyword FALSE ###< create table crash_me10 (FALSE int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FALSE int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_ansi-92/99_fetch=no # Keyword FETCH ###< create table crash_me10 (FETCH int not null) ###> OK @@ -3223,7 +3226,7 @@ reserved_word_ansi-92/99_level=no # Keyword LEVEL ###As far as all queries returned OK, result is NO reserved_word_ansi-92/99_like=yes # Keyword LIKE ###< create table crash_me10 (LIKE int not null) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'LIKE int not null)' at line 1 + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 ###< drop table crash_me10 ###> execute error:Unknown table 'crash_me10' ### @@ -3466,13 +3469,13 @@ reserved_word_ansi-92/99_parameters=no # Keyword PARAMETERS ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi-92/99_partial=yes # Keyword PARTIAL +reserved_word_ansi-92/99_partial=no # Keyword PARTIAL ###< create table crash_me10 (PARTIAL int not null) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PARTIAL int not null)' at line 1 + ###> OK ###< drop table crash_me10 - ###> execute error:Unknown table 'crash_me10' + ###> OK ### - ###As far as some queries didnt return OK, result is YES + ###As far as all queries returned OK, result is NO reserved_word_ansi-92/99_precision=yes # Keyword PRECISION ###< create table crash_me10 (PRECISION int not null) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'PRECISION int not null)' at line 1 @@ -3900,13 +3903,13 @@ reserved_word_ansi-92/99_trigger=no # Keyword TRIGGER ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi-92/99_true=no # Keyword TRUE +reserved_word_ansi-92/99_true=yes # Keyword TRUE ###< create table crash_me10 (TRUE int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'TRUE int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_ansi-92/99_under=no # Keyword UNDER ###< create table crash_me10 (UNDER int not null) ###> OK @@ -4124,13 +4127,13 @@ reserved_word_ansi92_coalesce=no # Keyword COALESCE ###> OK ### ###As far as all queries returned OK, result is NO -reserved_word_ansi92_convert=no # Keyword CONVERT +reserved_word_ansi92_convert=yes # Keyword CONVERT ###< create table crash_me10 (CONVERT int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'CONVERT int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_ansi92_count=no # Keyword COUNT ###< create table crash_me10 (COUNT int not null) ###> OK @@ -5321,13 +5324,13 @@ reserved_word_extra_low_priority=yes # Keyword LOW_PRIORITY ###> execute error:Unknown table 'crash_me10' ### ###As far as some queries didnt return OK, result is YES -reserved_word_extra_master_server_id=yes # Keyword MASTER_SERVER_ID +reserved_word_extra_master_server_id=no # Keyword MASTER_SERVER_ID ###< create table crash_me10 (MASTER_SERVER_ID int not null) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'MASTER_SERVER_ID int not null)' at line 1 + ###> OK ###< drop table crash_me10 - ###> execute error:Unknown table 'crash_me10' + ###> OK ### - ###As far as some queries didnt return OK, result is YES + ###As far as all queries returned OK, result is NO reserved_word_extra_maxextents=no # Keyword MAXEXTENTS ###< create table crash_me10 (MAXEXTENTS int not null) ###> OK @@ -5720,13 +5723,13 @@ reserved_word_extra_soname=yes # Keyword SONAME ###> execute error:Unknown table 'crash_me10' ### ###As far as some queries didnt return OK, result is YES -reserved_word_extra_spatial=no # Keyword SPATIAL +reserved_word_extra_spatial=yes # Keyword SPATIAL ###< create table crash_me10 (SPATIAL int not null) - ###> OK + ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'int not null)' at line 1 ###< drop table crash_me10 - ###> OK + ###> execute error:Unknown table 'crash_me10' ### - ###As far as all queries returned OK, result is NO + ###As far as some queries didnt return OK, result is YES reserved_word_extra_sql_big_result=yes # Keyword SQL_BIG_RESULT ###< create table crash_me10 (SQL_BIG_RESULT int not null) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'SQL_BIG_RESULT int not null)' at line 1 @@ -6038,13 +6041,16 @@ select_limit3=yes # SELECT with LIMIT # OFFSET # select_string_size=1048565 # constant string size in SELECT ###We are trying (example with N=5): ###select 'aaaaa' -select_table_update=no # Update with sub select +select_table_update=yes # Update with sub select ###< create table crash_q (a integer,b char(10)) ###> OK ###< insert into crash_q values(1,'c') ###> OK ###< update crash_q set b= (select b from crash_me where crash_q.a = crash_me.a) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select b from crash_me where crash_q.a = crash_me.a)' at line 1 + ###> OK + ### + ###<select b from crash_q + ###>a ### ###< drop table crash_q ###> OK @@ -6053,7 +6059,7 @@ select_without_from=yes # SELECT without FROM ###> OK ### ###As far as all queries returned OK, result is YES -server_version=MySQL 4.0.15 debug log/ # server version +server_version=MySQL 4.1.2 alpha # server version simple_joins=yes # ANSI SQL simple joins ###< select crash_me.a from crash_me, crash_me t0 ###> OK @@ -6148,11 +6154,11 @@ storage_of_float=round # Storage of float values ### ###< drop table crash_q ###> OK -subqueries=no # subqueries +subqueries=yes # subqueries ###< select a from crash_me where crash_me.a in (select max(a) from crash_me) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'select max(a) from crash_me)' at line 1 + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES table_alias=yes # Table alias ###< select b.a from crash_me as b ###> OK @@ -6220,7 +6226,7 @@ time_format_inresult=iso # Time format in result ###> OK ### ###< select a from crash_me_t - ###> 19:55:21 + ###> 13:49:05 ###< delete from crash_me_t ###> OK transactions=yes # transactions @@ -6439,13 +6445,13 @@ type_extra_line=no # Type line ###> execute error:Unknown table 'crash_q' ### ###As far as some queries didnt return OK, result is NO -type_extra_long=no # Type long +type_extra_long=yes # Type long ###< create table crash_q (q long) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near ')' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES type_extra_long_raw=no # Type long raw ###< create table crash_q (q long raw) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'raw)' at line 1 @@ -6558,20 +6564,20 @@ type_extra_path=no # Type path ###> execute error:Unknown table 'crash_q' ### ###As far as some queries didnt return OK, result is NO -type_extra_point=no # Type point +type_extra_point=yes # Type point ###< create table crash_q (q point) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'point)' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO -type_extra_polygon=no # Type polygon + ###As far as all queries returned OK, result is YES +type_extra_polygon=yes # Type polygon ###< create table crash_q (q polygon) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'polygon)' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES type_extra_raw(1_arg)=no # Type raw(1 arg) ###< create table crash_q (q raw(16)) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'raw(16))' at line 1 @@ -6593,13 +6599,13 @@ type_extra_rowid=no # Type rowid ###> execute error:Unknown table 'crash_q' ### ###As far as some queries didnt return OK, result is NO -type_extra_serial=no # Type serial +type_extra_serial=yes # Type serial ###< create table crash_q (q serial) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'serial)' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES type_extra_set(1_arg)=yes # Type set(1 arg) ###< create table crash_q (q set('red')) ###> OK @@ -6635,13 +6641,13 @@ type_extra_text=yes # Type text ###> OK ### ###As far as all queries returned OK, result is YES -type_extra_text(1_arg)=no # Type text(1 arg) +type_extra_text(1_arg)=yes # Type text(1 arg) ###< create table crash_q (q text(10)) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near '(10))' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES type_extra_timespan=no # Type timespan ###< create table crash_q (q timespan) ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'timespan)' at line 1 @@ -6726,13 +6732,13 @@ type_sql_bit_varying(1_arg)=no # Type bit varying(1 arg) ###> execute error:Unknown table 'crash_q' ### ###As far as some queries didnt return OK, result is NO -type_sql_boolean=no # Type boolean +type_sql_boolean=yes # Type boolean ###< create table crash_q (q boolean) - ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'boolean)' at line 1 + ###> OK ###< drop table crash_q - ###> execute error:Unknown table 'crash_q' + ###> OK ### - ###As far as some queries didnt return OK, result is NO + ###As far as all queries returned OK, result is YES type_sql_char(1_arg)=yes # Type char(1 arg) ###< create table crash_q (q char(1)) ###> OK @@ -7032,12 +7038,12 @@ unique_null_in_create=yes # unique null in create ###> OK ### ###As far as all queries returned OK, result is YES -value_of_false=not supported # Value of FALSE +value_of_false=0 # Value of FALSE ###<select FALSE - ###> execute failed:Unknown column 'FALSE' in 'field list' -value_of_true=not supported # Value of TRUE + ###>0 +value_of_true=1 # Value of TRUE ###<select TRUE - ###> execute failed:Unknown column 'TRUE' in 'field list' + ###>1 views=no # views ###< create view crash_q as select a from crash_me ###> execute error:You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'view crash_q as select a from crash_me' at line 1 diff --git a/sql-common/client.c b/sql-common/client.c index b94f3e1de38..4a4de33269b 100644 --- a/sql-common/client.c +++ b/sql-common/client.c @@ -2044,7 +2044,7 @@ error: /* Free alloced memory */ end_server(mysql); mysql_close_free(mysql); - if (!(client_flag & CLIENT_REMEMBER_OPTIONS)) + if (!(((ulong) client_flag) & CLIENT_REMEMBER_OPTIONS)) mysql_close_free_options(mysql); } DBUG_RETURN(0); diff --git a/sql/derror.cc b/sql/derror.cc index 53d0dc5b7e5..09f43d20044 100644 --- a/sql/derror.cc +++ b/sql/derror.cc @@ -50,7 +50,7 @@ static bool read_texts(const char *file_name,const char ***point, char name[FN_REFLEN]; const char *buff; uchar head[32],*pos; - CHARSET_INFO *cset; + CHARSET_INFO *cset; // For future DBUG_ENTER("read_texts"); *point=0; // If something goes wrong @@ -137,7 +137,7 @@ err1: if (file != FERR) VOID(my_close(file,MYF(MY_WME))); unireg_abort(1); - DBUG_RETURN(1); // Impossible + DBUG_RETURN(1); // keep compiler happy } /* read_texts */ diff --git a/sql/field.cc b/sql/field.cc index 238d5e36147..d099da2d959 100644 --- a/sql/field.cc +++ b/sql/field.cc @@ -161,13 +161,6 @@ static bool test_if_real(const char *str,int length, CHARSET_INFO *cs) } #endif -static inline uint field_length_without_space(const char *ptr, uint length) -{ - const char *end= ptr+length; - while (end > ptr && end[-1] == ' ') - end--; - return (uint) (end-ptr); -} /* Tables of filed type compatibility. @@ -306,7 +299,7 @@ Field::Field(char *ptr_arg,uint32 length_arg,uchar *null_ptr_arg, field_name(field_name_arg), query_id(0), key_start(0), part_of_key(0), part_of_sortkey(0), unireg_check(unireg_check_arg), - field_length(length_arg),null_bit(null_bit_arg),abs_offset(0) + field_length(length_arg),null_bit(null_bit_arg) { flags=null_ptr ? 0: NOT_NULL_FLAG; comment.str= (char*) ""; @@ -2789,14 +2782,8 @@ int Field_double::cmp(const char *a_ptr, const char *b_ptr) else #endif { -/* could this ALWAYS be 2 calls to doubleget() ?? */ -#if defined(__FLOAT_WORD_ORDER) && (__FLOAT_WORD_ORDER == __BIG_ENDIAN) doubleget(a, a_ptr); doubleget(b, b_ptr); -#else - memcpy_fixed(&a,a_ptr,sizeof(double)); - memcpy_fixed(&b,b_ptr,sizeof(double)); -#endif } return (a < b) ? -1 : (a > b) ? 1 : 0; } @@ -2816,12 +2803,7 @@ void Field_double::sort_string(char *to,uint length __attribute__((unused))) } else #endif -/* could this ALWAYS be 2 calls to doubleget() ?? */ -#if defined(__FLOAT_WORD_ORDER) && (__FLOAT_WORD_ORDER == __BIG_ENDIAN) doubleget(nr,ptr); -#else - memcpy_fixed(&nr,ptr,sizeof(nr)); -#endif change_double_for_sort(nr, (byte*) to); } @@ -5597,7 +5579,7 @@ uint32 calc_pack_length(enum_field_types type,uint32 length) case FIELD_TYPE_ENUM: abort(); return 0; // This shouldn't happen default: return 0; } - return 0; // This shouldn't happen + return 0; // Keep compiler happy } @@ -5630,6 +5612,18 @@ Field *make_field(char *ptr, uint32 field_length, null_pos=0; null_bit=0; } + + switch (field_type) + { + case FIELD_TYPE_DATE: + case FIELD_TYPE_NEWDATE: + case FIELD_TYPE_TIME: + case FIELD_TYPE_DATETIME: + case FIELD_TYPE_TIMESTAMP: + field_charset= &my_charset_bin; + default: break; + } + if (f_is_alpha(pack_flag)) { if (!f_is_packed(pack_flag)) diff --git a/sql/field.h b/sql/field.h index 258c18257f0..75bb96f2f6d 100644 --- a/sql/field.h +++ b/sql/field.h @@ -87,7 +87,6 @@ public: uint32 field_length; // Length of field uint16 flags; uchar null_bit; // Bit used to test null bit - uint abs_offset; // use only in group_concat Field(char *ptr_arg,uint32 length_arg,uchar *null_ptr_arg,uchar null_bit_arg, utype unireg_check_arg, const char *field_name_arg, diff --git a/sql/filesort.cc b/sql/filesort.cc index a15ffb43f6f..8699a517661 100644 --- a/sql/filesort.cc +++ b/sql/filesort.cc @@ -663,9 +663,22 @@ static void make_sortkey(register SORTPARAM *param, for ( ; (field= addonf->field) ; addonf++) { if (addonf->null_bit && field->is_null()) + { nulls[addonf->null_offset]|= addonf->null_bit; +#ifdef HAVE_purify + bzero(to, addonf->length); +#endif + } else - field->pack((char *) to, field->ptr); + { + uchar *end= (uchar*) field->pack((char *) to, field->ptr); +#ifdef HAVE_purify + uint length= (uint) ((to + addonf->length) - end); + DBUG_ASSERT((int) length >= 0); + if (length) + bzero(end, length); +#endif + } to+= addonf->length; } } diff --git a/sql/ha_innodb.cc b/sql/ha_innodb.cc index 307bd13885c..80721ae373c 100644 --- a/sql/ha_innodb.cc +++ b/sql/ha_innodb.cc @@ -134,7 +134,6 @@ static mysql_byte* innobase_get_key(INNOBASE_SHARE *share,uint *length, my_bool not_used __attribute__((unused))); static INNOBASE_SHARE *get_share(const char *table_name); static void free_share(INNOBASE_SHARE *share); -static void innobase_print_error(const char* db_errpfx, char* buffer); /* General functions */ @@ -1292,18 +1291,6 @@ innobase_close_connection( return(0); } -/********************************************************************** -Prints an error message. */ -static -void -innobase_print_error( -/*=================*/ - const char* db_errpfx, /* in: error prefix text */ - char* buffer) /* in: error text */ -{ - sql_print_error("%s: %s", db_errpfx, buffer); -} - /***************************************************************************** ** InnoDB database tables diff --git a/sql/ha_myisam.cc b/sql/ha_myisam.cc index 6ac3c52fe40..427edde2f4b 100644 --- a/sql/ha_myisam.cc +++ b/sql/ha_myisam.cc @@ -841,14 +841,11 @@ void ha_myisam::deactivate_non_unique_index(ha_rows rows) if (file->state->records == 0 && (!rows || rows >= MI_MIN_ROWS_TO_DISABLE_INDEXES)) mi_disable_non_unique_index(file,rows); - else - if (!file->bulk_insert && - (!rows || rows >= MI_MIN_ROWS_TO_USE_BULK_INSERT)) - { + else if (!file->bulk_insert && + (!rows || rows >= MI_MIN_ROWS_TO_USE_BULK_INSERT)) mi_init_bulk_insert(file, current_thd->variables.bulk_insert_buff_size, rows); - } } } enable_activate_all_index=1; diff --git a/sql/init.cc b/sql/init.cc index 084db57f8aa..4beb8db0c6f 100644 --- a/sql/init.cc +++ b/sql/init.cc @@ -46,7 +46,5 @@ void unireg_init(ulong options) log_10[i]= nr ; nr*= 10.0; } specialflag|=options; /* Set options from argv */ - - thread_stack_min=thread_stack - STACK_MIN_SIZE; DBUG_VOID_RETURN; } diff --git a/sql/item.cc b/sql/item.cc index 1efed78799a..a0ca28ebd99 100644 --- a/sql/item.cc +++ b/sql/item.cc @@ -771,7 +771,6 @@ String *Item_param::query_val_str(String* str) case INT_RESULT: case REAL_RESULT: return val_str(str); - break; default: str->set("'", 1, default_charset()); diff --git a/sql/item_cmpfunc.cc b/sql/item_cmpfunc.cc index 24d60b51eab..ae6658c8e35 100644 --- a/sql/item_cmpfunc.cc +++ b/sql/item_cmpfunc.cc @@ -1472,16 +1472,12 @@ cmp_item* cmp_item::get_comparator(Item *item) switch (item->result_type()) { case STRING_RESULT: return new cmp_item_sort_string(item->collation.collation); - break; case INT_RESULT: return new cmp_item_int; - break; case REAL_RESULT: return new cmp_item_real; - break; case ROW_RESULT: return new cmp_item_row; - break; default: DBUG_ASSERT(0); break; diff --git a/sql/item_func.cc b/sql/item_func.cc index fdc0ee9d6a0..d7e778171a0 100644 --- a/sql/item_func.cc +++ b/sql/item_func.cc @@ -1143,7 +1143,6 @@ String *Item_func_min_max::val_str(String *str) // This case should never be choosen DBUG_ASSERT(0); return 0; - } return 0; // Keep compiler happy } @@ -2442,7 +2441,6 @@ Item_func_set_user_var::check() save_result.vint= args[0]->val_int(); break; } - break; case STRING_RESULT: { save_result.vstr= args[0]->val_str(&value); @@ -2494,7 +2492,6 @@ Item_func_set_user_var::update() INT_RESULT, &my_charset_bin, DERIVATION_NONE); break; } - break; case STRING_RESULT: { if (!save_result.vstr) // Null value diff --git a/sql/item_geofunc.cc b/sql/item_geofunc.cc index a1305e0b1d9..555c1a74eaf 100644 --- a/sql/item_geofunc.cc +++ b/sql/item_geofunc.cc @@ -66,7 +66,6 @@ String *Item_func_geometry_from_wkb::val_str(String *str) String arg_val; String *wkb= args[0]->val_str(&arg_val); Geometry_buffer buffer; - Geometry *geom; uint32 srid= 0; if ((arg_count == 2) && !args[1]->null_value) @@ -78,7 +77,7 @@ String *Item_func_geometry_from_wkb::val_str(String *str) str->q_append(srid); if ((null_value= (args[0]->null_value || - !(geom= Geometry::create_from_wkb(&buffer, wkb->ptr(), wkb->length())) || + !Geometry::create_from_wkb(&buffer, wkb->ptr(), wkb->length()) || str->append(*wkb)))) return 0; return str; @@ -126,12 +125,11 @@ String *Item_func_as_wkb::val_str(String *str) String arg_val; String *swkb= args[0]->val_str(&arg_val); Geometry_buffer buffer; - Geometry *geom; if ((null_value= (args[0]->null_value || - !(geom= Geometry::create_from_wkb(&buffer, swkb->ptr() + SRID_SIZE, - swkb->length() - SRID_SIZE))))) + !(Geometry::create_from_wkb(&buffer, swkb->ptr() + SRID_SIZE, + swkb->length() - SRID_SIZE))))) return 0; str->copy(swkb->ptr() + SRID_SIZE, swkb->length() - SRID_SIZE, @@ -701,10 +699,10 @@ longlong Item_func_srid::val_int() Geometry_buffer buffer; Geometry *geom; - null_value= !swkb || - !(geom= Geometry::create_from_wkb(&buffer, - swkb->ptr() + SRID_SIZE, - swkb->length() - SRID_SIZE)); + null_value= (!swkb || + !Geometry::create_from_wkb(&buffer, + swkb->ptr() + SRID_SIZE, + swkb->length() - SRID_SIZE)); if (null_value) return 0; diff --git a/sql/item_sum.cc b/sql/item_sum.cc index 26b859c8aba..3213ff94ab5 100644 --- a/sql/item_sum.cc +++ b/sql/item_sum.cc @@ -41,7 +41,11 @@ Item_sum::Item_sum(List<Item> &list) list.empty(); // Fields are used } -// Constructor used in processing select with temporary tebles + +/* + Constructor used in processing select with temporary tebles +*/ + Item_sum::Item_sum(THD *thd, Item_sum *item): Item_result_field(thd, item), arg_count(item->arg_count), quick_group(item->quick_group) @@ -1538,10 +1542,17 @@ String *Item_sum_udf_str::val_str(String *str) /***************************************************************************** GROUP_CONCAT function - Syntax: - GROUP_CONCAT([DISTINCT] expr,... [ORDER BY col [ASC|DESC],...] - [SEPARATOR str_const]) + + SQL SYNTAX: + GROUP_CONCAT([DISTINCT] expr,... [ORDER BY col [ASC|DESC],...] + [SEPARATOR str_const]) + concat of values from "group by" operation + + BUGS + DISTINCT and ORDER BY only works if ORDER BY uses all fields and only fields + in expression list + Blobs doesn't work with DISTINCT or ORDER BY *****************************************************************************/ /* @@ -1552,25 +1563,28 @@ String *Item_sum_udf_str::val_str(String *str) int group_concat_key_cmp_with_distinct(void* arg, byte* key1, byte* key2) { - Item_func_group_concat* item= (Item_func_group_concat*)arg; + Item_func_group_concat* grp_item= (Item_func_group_concat*)arg; + Item **field_item, **end; + char *record= (char*) grp_item->table->record[0]; - for (uint i= 0; i < item->arg_count_field; i++) + for (field_item= grp_item->args, end= field_item + grp_item->arg_count_field; + field_item < end; + field_item++) { - Item *field_item= item->args[i]; - Field *field= field_item->real_item()->get_tmp_table_field(); + /* + We have to use get_tmp_table_field() instead of + real_item()->get_tmp_table_field() because we want the field in + the temporary table, not the original field + */ + Field *field= (*field_item)->get_tmp_table_field(); if (field) { - uint offset= field->abs_offset; - - int res= field->key_cmp(key1 + offset, key2 + offset); - /* - if key1 and key2 is not equal than field->key_cmp return offset. This - function must return value 1 for this case. - */ - if (res) - return 1; + int res; + uint offset= (uint) (field->ptr - record); + if ((res= field->key_cmp(key1 + offset, key2 + offset))) + return res; } - } + } return 0; } @@ -1582,26 +1596,34 @@ int group_concat_key_cmp_with_distinct(void* arg, byte* key1, int group_concat_key_cmp_with_order(void* arg, byte* key1, byte* key2) { - Item_func_group_concat* item= (Item_func_group_concat*)arg; + Item_func_group_concat* grp_item= (Item_func_group_concat*) arg; + ORDER **order_item, **end; + char *record= (char*) grp_item->table->record[0]; - for (uint i=0; i < item->arg_count_order; i++) + for (order_item= grp_item->order, end=order_item+ grp_item->arg_count_order; + order_item < end; + order_item++) { - ORDER *order_item= item->order[i]; - Item *item= *order_item->item; - Field *field= item->real_item()->get_tmp_table_field(); + Item *item= *(*order_item)->item; + /* + We have to use get_tmp_table_field() instead of + real_item()->get_tmp_table_field() because we want the field in + the temporary table, not the original field + */ + Field *field= item->get_tmp_table_field(); if (field) { - uint offset= field->abs_offset; - - bool dir= order_item->asc; - int res= field->key_cmp(key1 + offset, key2 + offset); - if (res) - return dir ? res : -res; + int res; + uint offset= (uint) (field->ptr - record); + if ((res= field->key_cmp(key1 + offset, key2 + offset))) + return (*order_item)->asc ? res : -res; } - } + } /* - We can't return 0 because tree class remove this item as double value. - */ + We can't return 0 because in that case the tree class would remove this + item as double value. This would cause problems for case-changes and + if the the returned values are not the same we do the sort on. + */ return 1; } @@ -1609,6 +1631,11 @@ int group_concat_key_cmp_with_order(void* arg, byte* key1, byte* key2) /* function of sort for syntax: GROUP_CONCAT(DISTINCT expr,... ORDER BY col,... ) + + BUG: + This doesn't work in the case when the order by contains data that + is not part of the field list because tree-insert will not notice + the duplicated values when inserting things sorted by ORDER BY */ int group_concat_key_cmp_with_distinct_and_order(void* arg,byte* key1, @@ -1621,58 +1648,61 @@ int group_concat_key_cmp_with_distinct_and_order(void* arg,byte* key1, /* - create result - item is pointer to Item_func_group_concat + Append data from current leaf to item->result */ int dump_leaf_key(byte* key, uint32 count __attribute__((unused)), - Item_func_group_concat *group_concat_item) + Item_func_group_concat *item) { char buff[MAX_FIELD_WIDTH]; - String tmp((char *)&buff,sizeof(buff),default_charset_info); - String tmp2((char *)&buff,sizeof(buff),default_charset_info); - + String tmp((char*) &buff, sizeof(buff), default_charset_info); + String tmp2((char *) &buff, sizeof(buff), default_charset_info); + char *record= (char*) item->table->record[0]; + tmp.length(0); - for (uint i= 0; i < group_concat_item->arg_show_fields; i++) + for (uint i= 0; i < item->arg_count_field; i++) { - Item *show_item= group_concat_item->args[i]; + Item *show_item= item->args[i]; if (!show_item->const_item()) { - Field *f= show_item->real_item()->get_tmp_table_field(); - char *sv= f->ptr; - f->ptr= (char *)key + f->abs_offset; - String *res= f->val_str(&tmp,&tmp2); - group_concat_item->result.append(*res); - f->ptr= sv; + /* + We have to use get_tmp_table_field() instead of + real_item()->get_tmp_table_field() because we want the field in + the temporary table, not the original field + */ + Field *field= show_item->get_tmp_table_field(); + String *res; + char *save_ptr= field->ptr; + uint offset= (uint) (save_ptr - record); + DBUG_ASSERT(offset < item->table->reclength); + field->ptr= (char *) key + offset; + res= field->val_str(&tmp,&tmp2); + item->result.append(*res); + field->ptr= save_ptr; } else { String *res= show_item->val_str(&tmp); if (res) - group_concat_item->result.append(*res); + item->result.append(*res); } } - if (group_concat_item->tree_mode) // Last item of tree + if (item->tree_mode) // Last item of tree { - group_concat_item->show_elements++; - if (group_concat_item->show_elements < - group_concat_item->tree->elements_in_tree) - group_concat_item->result.append(*group_concat_item->separator); + item->show_elements++; + if (item->show_elements < item->tree->elements_in_tree) + item->result.append(*item->separator); } else + item->result.append(*item->separator); + + /* stop if length of result more than group_concat_max_len */ + if (item->result.length() > item->group_concat_max_len) { - group_concat_item->result.append(*group_concat_item->separator); - } - /* - if length of result more than group_concat_max_len - stop ! - */ - if (group_concat_item->result.length() > - group_concat_item->group_concat_max_len) - { - group_concat_item->count_cut_values++; - group_concat_item->result.length(group_concat_item->group_concat_max_len); - group_concat_item->warning_for_row= TRUE; + item->count_cut_values++; + item->result.length(item->group_concat_max_len); + item->warning_for_row= TRUE; return 1; } return 0; @@ -1692,56 +1722,86 @@ Item_func_group_concat::Item_func_group_concat(bool is_distinct, SQL_LIST *is_order, String *is_separator) :Item_sum(), tmp_table_param(0), max_elements_in_tree(0), warning(0), - warning_available(0), key_length(0), rec_offset(0), + warning_available(0), key_length(0), tree_mode(0), distinct(is_distinct), warning_for_row(0), separator(is_separator), tree(&tree_base), table(0), order(0), tables_list(0), show_elements(0), arg_count_order(0), arg_count_field(0), - arg_show_fields(0), count_cut_values(0) - + count_cut_values(0) { + Item *item_select; + Item **arg_ptr; + original= 0; quick_group= 0; mark_as_sum_func(); order= 0; group_concat_max_len= current_thd->variables.group_concat_max_len; - - arg_show_fields= arg_count_field= is_select->elements; + arg_count_field= is_select->elements; arg_count_order= is_order ? is_order->elements : 0; - arg_count= arg_count_field; + arg_count= arg_count_field + arg_count_order; /* We need to allocate: - args - arg_count+arg_count_order (for possible order items in temporare - tables) + args - arg_count_field+arg_count_order + (for possible order items in temporare tables) order - arg_count_order */ - args= (Item**) sql_alloc(sizeof(Item*)*(arg_count+arg_count_order)+ - sizeof(ORDER*)*arg_count_order); - if (!args) + if (!(args= (Item**) sql_alloc(sizeof(Item*) * arg_count + + sizeof(ORDER*)*arg_count_order))) return; + order= (ORDER**)(args + arg_count); + /* fill args items of show and sort */ - int i= 0; List_iterator_fast<Item> li(*is_select); - Item *item_select; - for ( ; (item_select= li++) ; i++) - args[i]= item_select; + for (arg_ptr=args ; (item_select= li++) ; arg_ptr++) + *arg_ptr= item_select; if (arg_count_order) { - i= 0; - order= (ORDER**)(args + arg_count + arg_count_order); + ORDER **order_ptr= order; for (ORDER *order_item= (ORDER*) is_order->first; - order_item != NULL; - order_item= order_item->next) + order_item != NULL; + order_item= order_item->next) { - order[i++]= order_item; + (*order_ptr++)= order_item; + *arg_ptr= *order_item->item; + order_item->item= arg_ptr++; } } } + + +Item_func_group_concat::Item_func_group_concat(THD *thd, + Item_func_group_concat *item) + :Item_sum(thd, item),item_thd(thd), + tmp_table_param(item->tmp_table_param), + max_elements_in_tree(item->max_elements_in_tree), + warning(item->warning), + warning_available(item->warning_available), + key_length(item->key_length), + tree_mode(item->tree_mode), + distinct(item->distinct), + warning_for_row(item->warning_for_row), + separator(item->separator), + tree(item->tree), + table(item->table), + order(item->order), + tables_list(item->tables_list), + group_concat_max_len(item->group_concat_max_len), + show_elements(item->show_elements), + arg_count_order(item->arg_count_order), + arg_count_field(item->arg_count_field), + field_list_offset(item->field_list_offset), + count_cut_values(item->count_cut_values), + original(item) +{ + quick_group= item->quick_group; +} + void Item_func_group_concat::cleanup() @@ -1785,12 +1845,11 @@ Item_func_group_concat::~Item_func_group_concat() */ if (!original) { - THD *thd= current_thd; if (warning_available) { char warn_buff[MYSQL_ERRMSG_SIZE]; sprintf(warn_buff, ER(ER_CUT_VALUE_GROUP_CONCAT), count_cut_values); - warning->set_msg(thd, warn_buff); + warning->set_msg(current_thd, warn_buff); } } } @@ -1826,33 +1885,31 @@ bool Item_func_group_concat::add() copy_fields(tmp_table_param); copy_funcs(tmp_table_param->items_to_copy); - bool record_is_null= TRUE; - for (uint i= 0; i < arg_show_fields; i++) + for (uint i= 0; i < arg_count_field; i++) { Item *show_item= args[i]; if (!show_item->const_item()) { + /* + Here we use real_item as we want the original field data that should + be written to table->record[0] + */ Field *f= show_item->real_item()->get_tmp_table_field(); - if (!f->is_null()) - { - record_is_null= FALSE; - break; - } + if (f->is_null()) + return 0; // Skip row if it contains null } } - if (record_is_null) - return 0; + null_value= FALSE; if (tree_mode) { - if (!tree_insert(tree, table->record[0] + rec_offset, 0, tree->custom_arg)) + if (!tree_insert(tree, table->record[0], 0, tree->custom_arg)) return 1; } else { if (result.length() <= group_concat_max_len && !warning_for_row) - dump_leaf_key(table->record[0] + rec_offset, 1, - (Item_func_group_concat*)this); + dump_leaf_key(table->record[0], 1, this); } return 0; } @@ -1884,24 +1941,19 @@ Item_func_group_concat::fix_fields(THD *thd, TABLE_LIST *tables, Item **ref) thd->allow_sum_func= 0; maybe_null= 0; item_thd= thd; - for (i= 0 ; i < arg_count ; i++) - { - if (args[i]->fix_fields(thd, tables, args + i) || args[i]->check_cols(1)) - return 1; - maybe_null |= args[i]->maybe_null; - } + /* - Fix fields for order clause in function: - GROUP_CONCAT(expr,... ORDER BY col,... ) + Fix fields for select list and ORDER clause */ - for (i= 0 ; i < arg_count_order ; i++) + + for (i= 0 ; i < arg_count ; i++) { - // order_item->item can be changed by fix_fields() call - ORDER *order_item= order[i]; - if ((*order_item->item)->fix_fields(thd, tables, order_item->item) || - (*order_item->item)->check_cols(1)) + if (args[i]->fix_fields(thd, tables, args + i) || args[i]->check_cols(1)) return 1; + if (i < arg_count_field && args[i]->maybe_null) + maybe_null= 0; } + result_field= 0; null_value= 1; max_length= group_concat_max_len; @@ -1916,23 +1968,29 @@ Item_func_group_concat::fix_fields(THD *thd, TABLE_LIST *tables, Item **ref) bool Item_func_group_concat::setup(THD *thd) { - DBUG_ENTER("Item_func_group_concat::setup"); List<Item> list; SELECT_LEX *select_lex= thd->lex->current_select; + uint const_fields; + byte *record; + qsort_cmp2 compare_key; + DBUG_ENTER("Item_func_group_concat::setup"); if (select_lex->linkage == GLOBAL_OPTIONS_TYPE) DBUG_RETURN(1); + /* push all not constant fields to list and create temp table */ + const_fields= 0; always_null= 0; - for (uint i= 0; i < arg_count; i++) + for (uint i= 0; i < arg_count_field; i++) { Item *item= args[i]; if (list.push_back(item)) DBUG_RETURN(1); if (item->const_item()) { + const_fields++; (void) item->val_int(); if (item->null_value) always_null= 1; @@ -1952,12 +2010,19 @@ bool Item_func_group_concat::setup(THD *thd) count_field_types(tmp_table_param,all_fields,0); if (table) { + /* + We come here when we are getting the result from a temporary table, + not the original tables used in the query + */ free_tmp_table(thd, table); tmp_table_param->cleanup(); } /* - We have to create a temporary table for that we get descriptions of fields + We have to create a temporary table to get descriptions of fields (types, sizes and so on). + + Note that in the table, we first have the ORDER BY fields, then the + field list. */ if (!(table=create_tmp_table(thd, tmp_table_param, all_fields, 0, 0, 0, 0,select_lex->options | thd->options, @@ -1966,27 +2031,17 @@ bool Item_func_group_concat::setup(THD *thd) table->file->extra(HA_EXTRA_NO_ROWS); table->no_rows= 1; + key_length= table->reclength; + record= table->record[0]; - Field** field, **field_end; - field_end = (field = table->field) + table->fields; - uint offset = 0; - for (key_length = 0; field < field_end; ++field) - { - uint32 length= (*field)->pack_length(); - (*field)->abs_offset= offset; - offset+= length; - key_length += length; - } - rec_offset = table->reclength - key_length; - + /* Offset to first result field in table */ + field_list_offset= table->fields - (list.elements - const_fields); if (tree_mode) delete_tree(tree); - /* - choise function of sort - */ + + /* choose function of sort */ tree_mode= distinct || arg_count_order; - qsort_cmp2 compare_key; if (tree_mode) { if (arg_count_order) @@ -1998,21 +2053,20 @@ bool Item_func_group_concat::setup(THD *thd) } else { + compare_key= NULL; if (distinct) compare_key= (qsort_cmp2) group_concat_key_cmp_with_distinct; - else - compare_key= NULL; } /* - Create a tree of sort. Tree is used for a sort and a remove dubl - values (according with syntax of the function). If function does't + Create a tree of sort. Tree is used for a sort and a remove double + values (according with syntax of the function). If function doesn't contain DISTINCT and ORDER BY clauses, we don't create this tree. */ init_tree(tree, min(thd->variables.max_heap_table_size, - thd->variables.sortbuff_size/16), 0, + thd->variables.sortbuff_size/16), 0, key_length, compare_key, 0, NULL, (void*) this); - max_elements_in_tree= ((key_length) ? - thd->variables.max_heap_table_size/key_length : 1); + max_elements_in_tree= (key_length ? + thd->variables.max_heap_table_size/key_length : 1); }; /* @@ -2027,6 +2081,7 @@ bool Item_func_group_concat::setup(THD *thd) DBUG_RETURN(0); } + /* This is used by rollup to create a separate usable copy of the function */ void Item_func_group_concat::make_unique() @@ -2069,7 +2124,7 @@ void Item_func_group_concat::print(String *str) str->append("group_concat(", 13); if (distinct) str->append("distinct ", 9); - for (uint i= 0; i < arg_count; i++) + for (uint i= 0; i < arg_count_field; i++) { if (i) str->append(','); diff --git a/sql/item_sum.h b/sql/item_sum.h index 8a51a7e5a7c..107c19b7d85 100644 --- a/sql/item_sum.h +++ b/sql/item_sum.h @@ -197,18 +197,24 @@ class Item_sum_count_distinct :public Item_sum_int uint key_length; CHARSET_INFO *key_charset; - // calculated based on max_heap_table_size. If reached, - // walk the tree and dump it into MyISAM table + /* + Calculated based on max_heap_table_size. If reached, + walk the tree and dump it into MyISAM table + */ uint max_elements_in_tree; - // the first few bytes of record ( at least one) - // are just markers for deleted and NULLs. We want to skip them since - // they will just bloat the tree without providing any valuable info + /* + The first few bytes of record ( at least one) + are just markers for deleted and NULLs. We want to skip them since + they will just bloat the tree without providing any valuable info + */ int rec_offset; - // If there are no blobs, we can use a tree, which - // is faster than heap table. In that case, we still use the table - // to help get things set up, but we insert nothing in it + /* + If there are no blobs, we can use a tree, which + is faster than heap table. In that case, we still use the table + to help get things set up, but we insert nothing in it + */ bool use_tree; bool always_null; // Set to 1 if the result is always NULL @@ -312,18 +318,17 @@ public: void fix_length_and_dec() {} }; -/* - -variance(a) = - -= sum (ai - avg(a))^2 / count(a) ) -= sum (ai^2 - 2*ai*avg(a) + avg(a)^2) / count(a) -= (sum(ai^2) - sum(2*ai*avg(a)) + sum(avg(a)^2))/count(a) = -= (sum(ai^2) - 2*avg(a)*sum(a) + count(a)*avg(a)^2)/count(a) = -= (sum(ai^2) - 2*sum(a)*sum(a)/count(a) + count(a)*sum(a)^2/count(a)^2 )/count(a) = -= (sum(ai^2) - 2*sum(a)^2/count(a) + sum(a)^2/count(a) )/count(a) = -= (sum(ai^2) - sum(a)^2/count(a))/count(a) +/* + variance(a) = + + = sum (ai - avg(a))^2 / count(a) ) + = sum (ai^2 - 2*ai*avg(a) + avg(a)^2) / count(a) + = (sum(ai^2) - sum(2*ai*avg(a)) + sum(avg(a)^2))/count(a) = + = (sum(ai^2) - 2*avg(a)*sum(a) + count(a)*avg(a)^2)/count(a) = + = (sum(ai^2) - 2*sum(a)*sum(a)/count(a) + count(a)*sum(a)^2/count(a)^2 )/count(a) = + = (sum(ai^2) - 2*sum(a)^2/count(a) + sum(a)^2/count(a) )/count(a) = + = (sum(ai^2) - sum(a)^2/count(a))/count(a) */ class Item_sum_variance : public Item_sum_num @@ -509,8 +514,9 @@ class Item_sum_xor :public Item_sum_bit /* -** user defined aggregates + User defined aggregates */ + #ifdef HAVE_DLOPEN class Item_udf_sum : public Item_sum @@ -668,7 +674,6 @@ class Item_func_group_concat : public Item_sum MYSQL_ERROR *warning; bool warning_available; uint key_length; - int rec_offset; bool tree_mode; bool distinct; bool warning_for_row; @@ -676,12 +681,13 @@ class Item_func_group_concat : public Item_sum friend int group_concat_key_cmp_with_distinct(void* arg, byte* key1, byte* key2); - friend int group_concat_key_cmp_with_order(void* arg, byte* key1, byte* key2); + friend int group_concat_key_cmp_with_order(void* arg, byte* key1, + byte* key2); friend int group_concat_key_cmp_with_distinct_and_order(void* arg, byte* key1, byte* key2); friend int dump_leaf_key(byte* key, uint32 count __attribute__((unused)), - Item_func_group_concat *group_concat_item); + Item_func_group_concat *group_concat_item); public: String result; @@ -695,7 +701,7 @@ class Item_func_group_concat : public Item_sum uint show_elements; uint arg_count_order; uint arg_count_field; - uint arg_show_fields; + uint field_list_offset; uint count_cut_values; /* Following is 0 normal object and pointer to original one for copy @@ -706,38 +712,12 @@ class Item_func_group_concat : public Item_sum Item_func_group_concat(bool is_distinct,List<Item> *is_select, SQL_LIST *is_order,String *is_separator); - Item_func_group_concat(THD *thd, Item_func_group_concat *item) - :Item_sum(thd, item),item_thd(thd), - tmp_table_param(item->tmp_table_param), - max_elements_in_tree(item->max_elements_in_tree), - warning(item->warning), - warning_available(item->warning_available), - key_length(item->key_length), - rec_offset(item->rec_offset), - tree_mode(item->tree_mode), - distinct(item->distinct), - warning_for_row(item->warning_for_row), - separator(item->separator), - tree(item->tree), - table(item->table), - order(item->order), - tables_list(item->tables_list), - group_concat_max_len(item->group_concat_max_len), - show_elements(item->show_elements), - arg_count_order(item->arg_count_order), - arg_count_field(item->arg_count_field), - arg_show_fields(item->arg_show_fields), - count_cut_values(item->count_cut_values), - original(item) - { - quick_group= item->quick_group; - }; + Item_func_group_concat(THD *thd, Item_func_group_concat *item); ~Item_func_group_concat(); void cleanup(); enum Sumfunctype sum_func () const {return GROUP_CONCAT_FUNC;} const char *func_name() const { return "group_concat"; } - enum Type type() const { return SUM_FUNC_ITEM; } virtual Item_result result_type () const { return STRING_RESULT; } void clear(); bool add(); diff --git a/sql/lex.h b/sql/lex.h index ceef140b5f7..94ea0295f05 100644 --- a/sql/lex.h +++ b/sql/lex.h @@ -122,6 +122,7 @@ static SYMBOL symbols[] = { { "CURRENT_DATE", SYM(CURDATE)}, { "CURRENT_TIME", SYM(CURTIME)}, { "CURRENT_TIMESTAMP", SYM(NOW_SYM)}, + { "CURRENT_USER", SYM(CURRENT_USER)}, { "DATA", SYM(DATA_SYM)}, { "DATABASE", SYM(DATABASE)}, { "DATABASES", SYM(DATABASES)}, @@ -481,7 +482,6 @@ static SYMBOL sql_functions[] = { { "CAST", SYM(CAST_SYM)}, { "CEIL", F_SYM(FUNC_ARG1),0,CREATE_FUNC(create_func_ceiling)}, { "CEILING", F_SYM(FUNC_ARG1),0,CREATE_FUNC(create_func_ceiling)}, - { "CURRENT_USER", F_SYM(FUNC_ARG0),0,CREATE_FUNC(create_func_current_user)}, { "BIT_LENGTH", F_SYM(FUNC_ARG1),0,CREATE_FUNC(create_func_bit_length)}, { "CENTROID", F_SYM(FUNC_ARG1),0,CREATE_FUNC_GEOM(create_func_centroid)}, { "CHAR_LENGTH", F_SYM(FUNC_ARG1),0,CREATE_FUNC(create_func_char_length)}, diff --git a/sql/log.cc b/sql/log.cc index 6b091484a82..0cd9e7172c3 100644 --- a/sql/log.cc +++ b/sql/log.cc @@ -507,7 +507,6 @@ int MYSQL_LOG::find_log_pos(LOG_INFO *linfo, const char *log_name, RETURN VALUES 0 ok LOG_INFO_EOF End of log-index-file found - LOG_INFO_SEEK Could not allocate IO cache LOG_INFO_IO Got IO error while reading file */ diff --git a/sql/log_event.cc b/sql/log_event.cc index 8ee2f055fc6..3b92e0956ba 100644 --- a/sql/log_event.cc +++ b/sql/log_event.cc @@ -83,7 +83,7 @@ inline int ignored_error_code(int err_code) pretty_print_str() */ -#ifndef MYSQL_CLIENT +#if defined(HAVE_REPLICATION) && !defined(MYSQL_CLIENT) static char *pretty_print_str(char *packet, char *str, int len) { char *end= str + len; diff --git a/sql/mysqld.cc b/sql/mysqld.cc index 0f75c7d14ef..c85f6ed4d8d 100644 --- a/sql/mysqld.cc +++ b/sql/mysqld.cc @@ -2105,13 +2105,11 @@ static int init_common_variables(const char *conf_file_name, int argc, strmov(fn_ext(pidfile_name),".pid"); // Add proper extension #ifndef DBUG_OFF - if (*(MYSQL_SERVER_SUFFIX)) - strxmov(strend(server_version),MYSQL_SERVER_SUFFIX,"-debug",NullS); + if (!*(MYSQL_SERVER_SUFFIX)) + strmov(strend(server_version),"-debug"); else - strmov(strend(server_version),"--debug"); -#else - strmov(strend(server_version),MYSQL_SERVER_SUFFIX); #endif + strmov(strend(server_version),MYSQL_SERVER_SUFFIX); load_defaults(conf_file_name, groups, &argc, &argv); defaults_argv=argv; @@ -2364,9 +2362,8 @@ Now disabling --log-slave-updates."); { if (global_system_variables.log_warnings) sql_print_error("Warning: Failed to lock memory. Errno: %d\n",errno); + locked_in_memory= 0; } - else - locked_in_memory=1; } #else locked_in_memory=0; @@ -2530,6 +2527,8 @@ int main(int argc, char **argv) } } #endif + thread_stack_min=thread_stack - STACK_MIN_SIZE; + (void) thr_setconcurrency(concurrency); // 10 by default /* diff --git a/sql/protocol.cc b/sql/protocol.cc index 40adc9e8961..fb4d2a57ab6 100644 --- a/sql/protocol.cc +++ b/sql/protocol.cc @@ -166,10 +166,10 @@ net_printf(THD *thd, uint errcode, ...) const char *format; #ifndef EMBEDDED_LIBRARY const char *text_pos; + int head_length= NET_HEADER_SIZE; #else char text_pos[1024]; #endif - int head_length= NET_HEADER_SIZE; NET *net= &thd->net; DBUG_ENTER("net_printf"); @@ -530,7 +530,10 @@ bool Protocol::send_fields(List<Item> *list, uint flag) /* Store fixed length fields */ pos= (char*) local_packet->ptr()+local_packet->length(); *pos++= 12; // Length of packed fields - int2store(pos, field.charsetnr); + if (item->collation.collation == &my_charset_bin || thd_charset == NULL) + int2store(pos, field.charsetnr); + else + int2store(pos, thd_charset->number); int4store(pos+2, field.length); pos[6]= field.type; int2store(pos+7,field.flags); diff --git a/sql/set_var.cc b/sql/set_var.cc index e3ed2a4cbd8..5c2cbecd52b 100644 --- a/sql/set_var.cc +++ b/sql/set_var.cc @@ -839,7 +839,8 @@ bool update_sys_var_str(sys_var_str *var_str, rw_lock_t *var_mutex, { char *res= 0, *old_value=(char *)(var ? var->value->str_value.ptr() : 0); uint new_length= (var ? var->value->str_value.length() : 0); - if (!old_value) old_value=""; + if (!old_value) + old_value= (char*) ""; if (!(res= my_strdup_with_length(old_value, new_length, MYF(0)))) return 1; /* diff --git a/sql/slave.cc b/sql/slave.cc index 53e72673a0e..67b9c7515e1 100644 --- a/sql/slave.cc +++ b/sql/slave.cc @@ -285,8 +285,9 @@ int init_relay_log_pos(RELAY_LOG_INFO* rli,const char* log, In this case, we will use the same IO_CACHE pointer to read data as the IO thread is using to write data. */ - if (my_b_tell((rli->cur_log=rli->relay_log.get_log_file())) == 0 && - check_binlog_magic(rli->cur_log,errmsg)) + rli->cur_log= rli->relay_log.get_log_file(); + if (my_b_tell(rli->cur_log) == 0 && + check_binlog_magic(rli->cur_log, errmsg)) goto err; rli->cur_log_old_open_count=rli->relay_log.get_open_count(); } @@ -1673,7 +1674,18 @@ int init_master_info(MASTER_INFO* mi, const char* master_info_fname, DBUG_ENTER("init_master_info"); if (mi->inited) + { + /* + We have to reset read position of relay-log-bin as we may have + already been reading from 'hotlog' when the slave was stopped + last time. If this case pos_in_file would be set and we would + get a crash when trying to read the signature for the binary + relay log. + */ + my_b_seek(mi->rli.cur_log, (my_off_t) 0); DBUG_RETURN(0); + } + mi->mysql=0; mi->file_id=1; fn_format(fname, master_info_fname, mysql_data_home, "", 4+32); @@ -3617,13 +3629,16 @@ int queue_event(MASTER_INFO* mi,const char* buf, ulong event_len) mi->master_log_pos+= inc_pos; DBUG_PRINT("info", ("master_log_pos: %d, event originating from the same server, ignored", (ulong) mi->master_log_pos)); } - else /* write the event to the relay log */ + else + { + /* write the event to the relay log */ if (likely(!(error= rli->relay_log.appendv(buf,event_len,0)))) { mi->master_log_pos+= inc_pos; DBUG_PRINT("info", ("master_log_pos: %d", (ulong) mi->master_log_pos)); rli->relay_log.harvest_bytes_written(&rli->log_space_total); } + } err: pthread_mutex_unlock(&mi->data_lock); @@ -4091,8 +4106,9 @@ Before assert, my_b_tell(cur_log)=%s rli->event_relay_log_pos=%s", if (rli->relay_log.is_active(rli->linfo.log_file_name)) { #ifdef EXTRA_DEBUG - sql_print_error("next log '%s' is currently active", - rli->linfo.log_file_name); + if (global_system_variables.log_warnings) + sql_print_error("next log '%s' is currently active", + rli->linfo.log_file_name); #endif rli->cur_log= cur_log= rli->relay_log.get_log_file(); rli->cur_log_old_open_count= rli->relay_log.get_open_count(); @@ -4120,8 +4136,9 @@ Before assert, my_b_tell(cur_log)=%s rli->event_relay_log_pos=%s", from hot to cold, but not from cold to hot). No need for LOCK_log. */ #ifdef EXTRA_DEBUG - sql_print_error("next log '%s' is not active", - rli->linfo.log_file_name); + if (global_system_variables.log_warnings) + sql_print_error("next log '%s' is not active", + rli->linfo.log_file_name); #endif // open_binlog() will check the magic header if ((rli->cur_log_fd=open_binlog(cur_log,rli->linfo.log_file_name, diff --git a/sql/sql_base.cc b/sql/sql_base.cc index 0862de073d3..93050419afa 100644 --- a/sql/sql_base.cc +++ b/sql/sql_base.cc @@ -1807,7 +1807,7 @@ Field *find_field_in_table(THD *thd,TABLE *table,const char *name,uint length, if (cached_field_index < table->fields && !my_strcasecmp(system_charset_info, table->field[cached_field_index]->field_name, name)) - field_ptr= table->field + cached_field_index; + field_ptr= table->field + cached_field_index; else if (table->name_hash.records) field_ptr= (Field**)hash_search(&table->name_hash,(byte*) name, length); diff --git a/sql/sql_cache.cc b/sql/sql_cache.cc index 39061a6501b..e1a15eff475 100644 --- a/sql/sql_cache.cc +++ b/sql/sql_cache.cc @@ -1860,11 +1860,11 @@ my_bool Query_cache::write_result_data(Query_cache_block **result_block, { // It is success (nobody can prevent us write data) STRUCT_UNLOCK(&structure_guard_mutex); - byte *rest = (byte*) data; - Query_cache_block *block = *result_block; uint headers_len = (ALIGN_SIZE(sizeof(Query_cache_block)) + ALIGN_SIZE(sizeof(Query_cache_result))); #ifndef EMBEDDED_LIBRARY + Query_cache_block *block= *result_block; + byte *rest= (byte*) data; // Now fill list of blocks that created by allocate_data_chain do { diff --git a/sql/sql_derived.cc b/sql/sql_derived.cc index ea47ca9f71d..81269a8cbcf 100644 --- a/sql/sql_derived.cc +++ b/sql/sql_derived.cc @@ -115,7 +115,6 @@ static int mysql_derived(THD *thd, LEX *lex, SELECT_LEX_UNIT *unit, TABLE *table; int res; select_union *derived_result; - TABLE_LIST *tables= (TABLE_LIST *)first_select->table_list.first; bool is_union= first_select->next_select() && first_select->next_select()->linkage == UNION_TYPE; bool is_subsel= first_select->first_inner_unit() ? 1: 0; diff --git a/sql/sql_insert.cc b/sql/sql_insert.cc index 0d0dff81427..241b293262f 100644 --- a/sql/sql_insert.cc +++ b/sql/sql_insert.cc @@ -21,12 +21,14 @@ #include "sql_acl.h" static int check_null_fields(THD *thd,TABLE *entry); +#ifndef EMBEDDED_LIBRARY static TABLE *delayed_get_table(THD *thd,TABLE_LIST *table_list); static int write_delayed(THD *thd,TABLE *table, enum_duplicates dup, char *query, uint query_length, int log_on); static void end_delayed_insert(THD *thd); extern "C" pthread_handler_decl(handle_delayed_insert,arg); static void unlink_blobs(register TABLE *table); +#endif /* Define to force use of my_malloc() if the allocated memory block is big */ @@ -127,7 +129,9 @@ int mysql_insert(THD *thd,TABLE_LIST *table_list, TABLE *table; List_iterator_fast<List_item> its(values_list); List_item *values; - char *query=thd->query; +#ifndef EMBEDDED_LIBRARY + char *query= thd->query; +#endif thr_lock_type lock_type = table_list->lock_type; TABLE_LIST *insert_table_list= (TABLE_LIST*) thd->lex->select_lex.table_list.first; diff --git a/sql/sql_lex.cc b/sql/sql_lex.cc index df7d487194a..4c63a8b7c7f 100644 --- a/sql/sql_lex.cc +++ b/sql/sql_lex.cc @@ -1389,7 +1389,7 @@ create_total_list_n_last_return(THD *thd_arg, } } } -end: + if (slave_list_first) { *new_table_list= slave_list_first; diff --git a/sql/sql_lex.h b/sql/sql_lex.h index c86c7d4a81d..5538fb0e832 100644 --- a/sql/sql_lex.h +++ b/sql/sql_lex.h @@ -396,6 +396,7 @@ public: SQL_LIST order_list; /* ORDER clause */ List<List_item> expr_list; List<List_item> when_list; /* WHEN clause (expression) */ + SQL_LIST *gorder_list; ha_rows select_limit, offset_limit; /* LIMIT clause parameters */ // Arrays of pointers to top elements of all_fields list Item **ref_pointer_array; @@ -538,7 +539,6 @@ typedef struct st_lex gptr yacc_yyss,yacc_yyvs; THD *thd; CHARSET_INFO *charset; - SQL_LIST *gorder_list; List<key_part_spec> col_list; List<key_part_spec> ref_list; diff --git a/sql/sql_parse.cc b/sql/sql_parse.cc index 100db9d1686..57e1079253b 100644 --- a/sql/sql_parse.cc +++ b/sql/sql_parse.cc @@ -48,7 +48,9 @@ extern "C" int gethostname(char *name, int namelen); #endif +#ifndef NO_EMBEDDED_ACCESS_CHECKS static int check_for_max_user_connections(THD *thd, USER_CONN *uc); +#endif static void decrease_user_connections(USER_CONN *uc); static bool check_db_used(THD *thd,TABLE_LIST *tables); static bool check_merge_table_access(THD *thd, char *db, TABLE_LIST *tables); @@ -426,6 +428,8 @@ void init_max_user_conn(void) 1 error */ +#ifndef NO_EMBEDDED_ACCESS_CHECKS + static int check_for_max_user_connections(THD *thd, USER_CONN *uc) { int error=0; @@ -456,7 +460,7 @@ static int check_for_max_user_connections(THD *thd, USER_CONN *uc) (void) pthread_mutex_unlock(&LOCK_user_conn); DBUG_RETURN(error); } - +#endif /* NO_EMBEDDED_ACCESS_CHECKS */ /* Decrease user connection count @@ -545,15 +549,15 @@ bool is_update_query(enum enum_sql_command command) static bool check_mqh(THD *thd, uint check_command) { +#ifdef NO_EMBEDDED_ACCESS_CHECKS + return(0); +#else bool error=0; time_t check_time = thd->start_time ? thd->start_time : time(NULL); USER_CONN *uc=thd->user_connect; DBUG_ENTER("check_mqh"); DBUG_ASSERT(uc != 0); -#ifdef NO_EMBEDDED_ACCESS_CHECKS - DBUG_RETURN(0); -#else /* If more than a hour since last check, reset resource checking */ if (check_time - uc->intime >= 3600) { @@ -3158,7 +3162,7 @@ unsent_create_error: net_printf(thd,ER_WRONG_DB_NAME, lex->name); break; } - if (check_access(thd,DROP_ACL,lex->name,0,1,0)) + if (check_access(thd,SELECT_ACL,lex->name,0,1,0)) break; if (thd->locked_tables || thd->active_transaction()) { @@ -3548,7 +3552,10 @@ check_access(THD *thd, ulong want_access, const char *db, ulong *save_priv, DBUG_ENTER("check_access"); DBUG_PRINT("enter",("want_access: %lu master_access: %lu", want_access, thd->master_access)); - ulong db_access,dummy; +#ifndef NO_EMBEDDED_ACCESS_CHECKS + ulong db_access; +#endif + ulong dummy; if (save_priv) *save_priv=0; else @@ -3740,6 +3747,10 @@ static bool check_db_used(THD *thd,TABLE_LIST *tables) #define used_stack(A,B) (long) (B - A) #endif +#ifndef DBUG_OFF +long max_stack_used; +#endif + #ifndef EMBEDDED_LIBRARY bool check_stack_overrun(THD *thd,char *buf __attribute__((unused))) { @@ -3752,6 +3763,9 @@ bool check_stack_overrun(THD *thd,char *buf __attribute__((unused))) thd->fatal_error(); return 1; } +#ifndef DBUG_OFF + max_stack_used= max(max_stack_used, stack_used); +#endif return 0; } #endif /* EMBEDDED_LIBRARY */ diff --git a/sql/sql_prepare.cc b/sql/sql_prepare.cc index 2b1adbf7afc..8072b151c5c 100644 --- a/sql/sql_prepare.cc +++ b/sql/sql_prepare.cc @@ -802,7 +802,7 @@ static int mysql_test_select_fields(Prepared_statement *stmt, if (check_table_access(thd, privilege, tables,0)) DBUG_RETURN(1); } - else if (check_access(thd, privilege, "*any*",0,0,0)) + else if (check_access(thd, privilege, any_db,0,0,0)) DBUG_RETURN(1); #endif if ((&lex->select_lex != lex->all_selects_list && @@ -1123,9 +1123,10 @@ static void reset_stmt_for_execute(Prepared_statement *stmt) void mysql_stmt_execute(THD *thd, char *packet, uint packet_length) { ulong stmt_id= uint4korr(packet); +#ifndef EMBEDDED_LIBRARY uchar *packet_end= (uchar *) packet + packet_length - 1; +#endif Prepared_statement *stmt; - DBUG_ENTER("mysql_stmt_execute"); packet+= 9; /* stmt_id + 5 bytes of flags */ diff --git a/sql/sql_select.cc b/sql/sql_select.cc index 598b53fe7dd..86b1dcfb4ee 100644 --- a/sql/sql_select.cc +++ b/sql/sql_select.cc @@ -3610,7 +3610,6 @@ static void make_join_readinfo(JOIN *join, uint options) { uint i; - SELECT_LEX *select_lex= &join->thd->lex->select_lex; bool statistics= test(!(join->select_options & SELECT_DESCRIBE)); DBUG_ENTER("make_join_readinfo"); @@ -3880,9 +3879,7 @@ JOIN::join_free(bool full) else { for (tab= join_tab, end= tab+tables; tab != end; tab++) - { tab->cleanup(); - } table= 0; } } @@ -4789,7 +4786,7 @@ Field *create_tmp_field(THD *thd, TABLE *table,Item *item, Item::Type type, else return new Field_double(item_sum->max_length,maybe_null, item->name, table, item_sum->decimals); - case Item_sum::VARIANCE_FUNC: /* Place for sum & count */ + case Item_sum::VARIANCE_FUNC: /* Place for sum & count */ case Item_sum::STD_FUNC: if (group) return new Field_string(sizeof(double)*2+sizeof(longlong), @@ -4817,17 +4814,19 @@ Field *create_tmp_field(THD *thd, TABLE *table,Item *item, Item::Type type, default: // This case should never be choosen DBUG_ASSERT(0); + thd->fatal_error(); return 0; } } - thd->fatal_error(); - return 0; // Error + /* We never come here */ } case Item::FIELD_ITEM: case Item::DEFAULT_VALUE_ITEM: - return create_tmp_field_from_field(thd, (*from_field= - ((Item_field*) item)->field), + { + Item_field *field= (Item_field*) item; + return create_tmp_field_from_field(thd, (*from_field= field->field), item, table, modify_item); + } case Item::FUNC_ITEM: case Item::COND_ITEM: case Item::FIELD_AVG_ITEM: @@ -8405,12 +8404,11 @@ setup_copy_fields(THD *thd, TMP_TABLE_PARAM *param, Item *pos; List_iterator_fast<Item> li(all_fields); Copy_field *copy; - DBUG_ENTER("setup_copy_fields"); res_selected_fields.empty(); res_all_fields.empty(); List_iterator_fast<Item> itr(res_all_fields); - uint i, border= all_fields.elements - elements; + DBUG_ENTER("setup_copy_fields"); if (!(copy=param->copy_field= new Copy_field[param->field_count])) goto err2; @@ -8545,6 +8543,23 @@ bool JOIN::alloc_func_list() } +/* + Initialize 'sum_funcs' array with all Item_sum objects + + SYNOPSIS + make_sum_func_list() + field_list All items + send_fields Items in select list + before_group_by Set to 1 if this is called before GROUP BY handling + + NOTES + Calls ::setup() for all item_sum objects in field_list + + RETURN + 0 ok + 1 error +*/ + bool JOIN::make_sum_func_list(List<Item> &field_list, List<Item> &send_fields, bool before_group_by) { @@ -8581,7 +8596,7 @@ bool JOIN::make_sum_func_list(List<Item> &field_list, List<Item> &send_fields, /* - Change all funcs and sum_funcs to fields in tmp table, and create + Change all funcs and sum_funcs to fields in tmp table, and create new list of all items. change_to_use_tmp_fields() @@ -9081,7 +9096,6 @@ static void select_describe(JOIN *join, bool need_tmp_table, bool need_order, List<Item> field_list; List<Item> item_list; THD *thd=join->thd; - SELECT_LEX *select_lex= &join->thd->lex->select_lex; select_result *result=join->result; Item *item_null= new Item_null(); CHARSET_INFO *cs= &my_charset_latin1; diff --git a/sql/sql_show.cc b/sql/sql_show.cc index f93004976f2..021064c6bfc 100644 --- a/sql/sql_show.cc +++ b/sql/sql_show.cc @@ -31,9 +31,11 @@ static const char *grant_names[]={ "select","insert","update","delete","create","drop","reload","shutdown", "process","file","grant","references","index","alter"}; +#ifndef NO_EMBEDDED_ACCESS_CHECKS static TYPELIB grant_types = { sizeof(grant_names)/sizeof(char **), "grant_types", grant_names}; +#endif static int mysql_find_files(THD *thd,List<char> *files, const char *db, const char *path, const char *wild, bool dir); @@ -367,7 +369,9 @@ mysql_find_files(THD *thd,List<char> *files, const char *db,const char *path, char *ext; MY_DIR *dirp; FILEINFO *file; +#ifndef NO_EMBEDDED_ACCESS_CHECKS uint col_access=thd->col_access; +#endif TABLE_LIST table_list; DBUG_ENTER("mysql_find_files"); @@ -829,7 +833,9 @@ int mysqld_show_create_db(THD *thd, char *dbname, char path[FN_REFLEN]; char buff[2048]; String buffer(buff, sizeof(buff), system_charset_info); +#ifndef NO_EMBEDDED_ACCESS_CHECKS uint db_access; +#endif bool found_libchar; HA_CREATE_INFO create; uint create_options = create_info ? create_info->options : 0; @@ -1138,7 +1144,6 @@ append_identifier(THD *thd, String *packet, const char *name, uint length) { const char *name_end; char quote_char; - uint part_len; if (thd->variables.sql_mode & MODE_ANSI_QUOTES) quote_char= '\"'; @@ -1274,7 +1279,7 @@ store_create_info(THD *thd, TABLE *table, String *packet) /* - Again we are using CURRENT_TIMESTAMP instead of NOW becaus eit is + Again we are using CURRENT_TIMESTAMP instead of NOW because it is more standard */ has_now_default= table->timestamp_field == field && diff --git a/sql/sql_table.cc b/sql/sql_table.cc index 5e358f76d3f..3352c3a5f17 100644 --- a/sql/sql_table.cc +++ b/sql/sql_table.cc @@ -628,15 +628,15 @@ int mysql_create_table(THD *thd,const char *db, const char *table_name, if (!timestamps) { sql_field->unireg_check= Field::TIMESTAMP_DNUN_FIELD; - ++timestamps_with_niladic; + timestamps_with_niladic++; } else sql_field->unireg_check= Field::NONE; } - else if(sql_field->unireg_check != Field::NONE) - ++timestamps_with_niladic; + else if (sql_field->unireg_check != Field::NONE) + timestamps_with_niladic++; - ++timestamps; + timestamps++; /* fall-through */ default: sql_field->pack_flag=(FIELDFLAG_NUMBER | @@ -1963,11 +1963,6 @@ int mysql_create_like_table(THD* thd, TABLE_LIST* table, /* Create a new table by copying from source table */ -#ifndef DBUG_OFF - // The code stated below is for test synchronization.test Bug #2385 - if (test_flags & TEST_SYNCHRONIZATION) - sleep(3); -#endif if (my_copy(src_path, dst_path, MYF(MY_WME|MY_DONT_OVERWRITE_FILE))) goto err; diff --git a/sql/sql_yacc.yy b/sql/sql_yacc.yy index 2d713ef5f5e..2daba654d47 100644 --- a/sql/sql_yacc.yy +++ b/sql/sql_yacc.yy @@ -210,6 +210,7 @@ bool my_yyoverflow(short **a, YYSTYPE **b,int *yystacksize); %token CONCURRENT %token CONSTRAINT %token CONVERT_SYM +%token CURRENT_USER %token DATABASES %token DATA_SYM %token DEFAULT @@ -2684,6 +2685,8 @@ simple_expr: $$= new Item_func_curtime_local($3); Lex->safe_to_cache_query=0; } + | CURRENT_USER optional_braces + { $$= create_func_current_user(); } | DATE_ADD_INTERVAL '(' expr ',' interval_expr interval ')' { $$= new Item_date_add_interval($3,$5,$6,0); } | DATE_SUB_INTERVAL '(' expr ',' interval_expr interval ')' @@ -3060,11 +3063,15 @@ sum_expr: { $$=new Item_sum_variance($3); } | SUM_SYM '(' in_sum_expr ')' { $$=new Item_sum_sum($3); } - | GROUP_CONCAT_SYM '(' opt_distinct expr_list opt_gorder_clause - opt_gconcat_separator ')' + | GROUP_CONCAT_SYM '(' opt_distinct + { Select->in_sum_expr++; } + expr_list opt_gorder_clause + opt_gconcat_separator + ')' { - $$=new Item_func_group_concat($3,$4,Lex->gorder_list,$6); - $4->empty(); + Select->in_sum_expr--; + $$=new Item_func_group_concat($3,$5,Select->gorder_list,$7); + $5->empty(); }; opt_distinct: @@ -3079,16 +3086,15 @@ opt_gconcat_separator: opt_gorder_clause: /* empty */ { - LEX *lex=Lex; - lex->gorder_list = NULL; + Select->gorder_list = NULL; } | order_clause { - LEX *lex=Lex; - lex->gorder_list= - (SQL_LIST*) sql_memdup((char*) &lex->current_select->order_list, + SELECT_LEX *select= Select; + select->gorder_list= + (SQL_LIST*) sql_memdup((char*) &select->order_list, sizeof(st_sql_list)); - lex->current_select->order_list.empty(); + select->order_list.empty(); }; @@ -4170,6 +4176,29 @@ show_param: { Lex->sql_command= SQLCOM_SHOW_LOGS; WARN_DEPRECATED("SHOW BDB LOGS", "SHOW ENGINE BDB LOGS"); } | LOGS_SYM { Lex->sql_command= SQLCOM_SHOW_LOGS; WARN_DEPRECATED("SHOW LOGS", "SHOW ENGINE BDB LOGS"); } + | GRANTS + { + LEX *lex=Lex; + lex->sql_command= SQLCOM_SHOW_GRANTS; + THD *thd= lex->thd; + LEX_USER *curr_user; + if (!(curr_user= (LEX_USER*) thd->alloc(sizeof(st_lex_user)))) + YYABORT; + curr_user->user.str= thd->priv_user; + curr_user->user.length= strlen(thd->priv_user); + if (*thd->priv_host != 0) + { + curr_user->host.str= thd->priv_host; + curr_user->host.length= strlen(thd->priv_host); + } + else + { + curr_user->host.str= (char *) "%"; + curr_user->host.length= 1; + } + curr_user->password.str=NullS; + lex->grant_user= curr_user; + } | GRANTS FOR_SYM user { LEX *lex=Lex; @@ -4760,7 +4789,25 @@ user: if (!($$=(LEX_USER*) thd->alloc(sizeof(st_lex_user)))) YYABORT; $$->user = $1; $$->host=$3; - }; + } + | CURRENT_USER optional_braces + { + THD *thd= YYTHD; + if (!($$=(LEX_USER*) thd->alloc(sizeof(st_lex_user)))) + YYABORT; + $$->user.str= thd->priv_user; + $$->user.length= strlen(thd->priv_user); + if (*thd->priv_host != 0) + { + $$->host.str= thd->priv_host; + $$->host.length= strlen(thd->priv_host); + } + else + { + $$->host.str= (char *) "%"; + $$->host.length= 1; + } + }; /* Keyword that we allow for identifiers */ diff --git a/sql/table.cc b/sql/table.cc index dcd0d39d855..23d99466a83 100644 --- a/sql/table.cc +++ b/sql/table.cc @@ -465,7 +465,6 @@ int openfrm(const char *name, const char *alias, uint db_stat, uint prgflag, goto err_not_open; /* purecov: inspected */ } reg_field->comment=comment; - reg_field->set_charset(charset); if (!(reg_field->flags & NOT_NULL_FLAG)) { if ((null_bit<<=1) == 256) @@ -1288,7 +1287,7 @@ bool check_db_name(char *name) /* Used to catch empty names and names with end space */ bool last_char_is_space= TRUE; - if (lower_case_table_names) + if (lower_case_table_names && name != any_db) my_casedn_str(files_charset_info, name); while (*name) |