|
Different outcome with slightly modified test:
SET SESSION old_mode='';
|
CREATE TABLE t (a INT) ENGINE=InnoDB;
|
ALTER TABLE mysql.innodb_index_stats MODIFY stat_description VARCHAR(1024) COLLATE utf8_bin;
|
DROP TABLE t;
|
Leads to:
|
10.6.2 6c39eaeb126328e7813b146ecf652d51e4508981 (Debug)
|
mysqld: /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:408: dberr_t dict_table_schema_check(const dict_table_schema_t*, char*, size_t): Assertion `table->cols[j].len < req_schema->columns[i].len' failed.
|
|
10.6.2 6c39eaeb126328e7813b146ecf652d51e4508981 (Debug)
|
Core was generated by `/test/MD120621-mariadb-10.6.2-linux-x86_64-dbg/bin/mysqld --no-defaults --core-'.
|
Program terminated with signal SIGABRT, Aborted.
|
#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:50
|
[Current thread is 1 (Thread 0x148cd4103700 (LWP 2945455))]
|
(gdb) bt
|
#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:50
|
#1 0x0000148cd6cc1859 in __GI_abort () at abort.c:79
|
#2 0x0000148cd6cc1729 in __assert_fail_base (fmt=0x148cd6e57588 "%s%s%s:%u: %s%sAssertion `%s' failed.\n%n", assertion=0x557fcbd53948 "table->cols[j].len < req_schema->columns[i].len", file=0x557fcbd53778 "/test/10.6_dbg/storage/innobase/dict/dict0stats.cc", line=408, function=<optimized out>) at assert.c:92
|
#3 0x0000148cd6cd2f36 in __GI___assert_fail (assertion=assertion@entry=0x557fcbd53948 "table->cols[j].len < req_schema->columns[i].len", file=file@entry=0x557fcbd53778 "/test/10.6_dbg/storage/innobase/dict/dict0stats.cc", line=line@entry=408, function=function@entry=0x557fcbd53878 "dberr_t dict_table_schema_check(const dict_table_schema_t*, char*, size_t)") at assert.c:101
|
#4 0x0000557fcb7f385f in dict_table_schema_check (req_schema=req_schema@entry=0x557fcc34de80 <index_stats_schema>, errstr=errstr@entry=0x148cd40ffea0 "\300", errstr_sz=errstr_sz@entry=512) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:408
|
#5 0x0000557fcb7f6c34 in dict_stats_persistent_storage_check (caller_has_dict_sys_mutex=caller_has_dict_sys_mutex@entry=true) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:503
|
#6 0x0000557fcb7f6cfd in dict_stats_exec_sql (pinfo=pinfo@entry=0x148c88024238, sql=sql@entry=0x557fcbd53b58 "PROCEDURE DELETE_FROM_TABLE_STATS () IS\nBEGIN\nDELETE FROM \"mysql/innodb_table_stats\" WHERE\ndatabase_name = :database_name AND\ntable_name = :table_name;\nEND;\n", trx=trx@entry=0x148cd43be290) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:536
|
#7 0x0000557fcb7f6ebb in dict_stats_delete_from_table_stats (database_name=database_name@entry=0x148cd4100130 "test", table_name=table_name@entry=0x148cd4100200 "t", trx=trx@entry=0x148cd43be290) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:3653
|
#8 0x0000557fcb8028c3 in trx_t::drop_table_statistics (this=this@entry=0x148cd43be290, name=<optimized out>) at /test/10.6_dbg/storage/innobase/dict/drop.cc:130
|
#9 0x0000557fcb4c910b in ha_innobase::delete_table (this=<optimized out>, name=<optimized out>) at /test/10.6_dbg/storage/innobase/handler/ha_innodb.cc:13376
|
#10 0x0000557fcb0c48e2 in hton_drop_table (hton=<optimized out>, path=<optimized out>) at /test/10.6_dbg/sql/handler.cc:576
|
#11 0x0000557fcb0ce1b2 in ha_delete_table (thd=thd@entry=0x148c88000db8, hton=hton@entry=0x557fcd1d3538, path=path@entry=0x148cd41018f0 "./test/t", db=db@entry=0x148cd41016c0, alias=alias@entry=0x148cd41016d0, generate_warning=generate_warning@entry=true) at /test/10.6_dbg/sql/handler.cc:3072
|
#12 0x0000557fcaeae682 in mysql_rm_table_no_locks (thd=thd@entry=0x148c88000db8, tables=tables@entry=0x148c88014060, current_db=current_db@entry=0x148c88000e50, ddl_log_state=0x148cd41016f0, ddl_log_state@entry=0x0, if_exists=if_exists@entry=false, drop_temporary=drop_temporary@entry=false, drop_view=false, drop_sequence=false, dont_log_query=false, dont_free_locks=false) at /test/10.6_dbg/sql/sql_table.cc:1471
|
#13 0x0000557fcaeb0779 in mysql_rm_table (thd=thd@entry=0x148c88000db8, tables=tables@entry=0x148c88014060, if_exists=<optimized out>, drop_temporary=<optimized out>, drop_sequence=<optimized out>, dont_log_query=dont_log_query@entry=false) at /test/10.6_dbg/sql/sql_table.cc:1044
|
#14 0x0000557fcadee0ad in mysql_execute_command (thd=thd@entry=0x148c88000db8) at /test/10.6_dbg/sql/structs.h:567
|
#15 0x0000557fcadd7890 in mysql_parse (thd=thd@entry=0x148c88000db8, rawbuf=<optimized out>, length=<optimized out>, parser_state=parser_state@entry=0x148cd4102400) at /test/10.6_dbg/sql/sql_parse.cc:8016
|
#16 0x0000557fcade63fa in dispatch_command (command=command@entry=COM_QUERY, thd=thd@entry=0x148c88000db8, packet=packet@entry=0x148c8800b769 "DROP TABLE t", packet_length=packet_length@entry=12, blocking=blocking@entry=true) at /test/10.6_dbg/sql/sql_class.h:1340
|
#17 0x0000557fcade97da in do_command (thd=0x148c88000db8, blocking=blocking@entry=true) at /test/10.6_dbg/sql/sql_parse.cc:1406
|
#18 0x0000557fcaf4dc8e in do_handle_one_connection (connect=<optimized out>, connect@entry=0x557fcd6be098, put_in_cache=put_in_cache@entry=true) at /test/10.6_dbg/sql/sql_connect.cc:1410
|
#19 0x0000557fcaf4e293 in handle_one_connection (arg=arg@entry=0x557fcd6be098) at /test/10.6_dbg/sql/sql_connect.cc:1312
|
#20 0x0000557fcb3fc166 in pfs_spawn_thread (arg=0x557fcd5a6cf8) at /test/10.6_dbg/storage/perfschema/pfs.cc:2201
|
#21 0x0000148cd71cf609 in start_thread (arg=<optimized out>) at pthread_create.c:477
|
#22 0x0000148cd6dbe293 in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:95
|
Bug confirmed present in:
MariaDB: 10.6.2 (dbg)
Bug (or feature/syntax) confirmed not present in:
MariaDB: 10.2.38 (dbg), 10.2.38 (opt), 10.3.29 (dbg), 10.3.29 (opt), 10.4.19 (dbg), 10.4.19 (opt), 10.5.10 (dbg), 10.5.10 (opt), 10.6.2 (opt)
MySQL: 5.5.62 (dbg), 5.5.62 (opt), 5.6.51 (dbg), 5.6.51 (opt), 5.7.34 (dbg), 5.7.34 (opt), 8.0.24 (dbg), 8.0.24 (opt)
|
|
Had one more testcase for this bug with slightly different uniqueID.
table->cols[j].len < req_schema->columns[i].len|SIGABRT|dict_table_schema_check|dict_stats_persistent_storage_check|dict_stats_update|dict_stats_init
|
Adding it for completeness.
SET sql_mode='';
|
CREATE TABLE t (a ENUM ('','') DEFAULT'');
|
SET SESSION old_mode=no_progress_info;
|
ALTER TABLE mysql.innodb_index_stats MODIFY stat_description VARCHAR(1024) COLLATE utf8_bin;
|
INSERT INTO t VALUES (0,0,36,'','','','');
|
Leads to:
|
10.6.2 6c39eaeb126328e7813b146ecf652d51e4508981 (Debug)
|
mysqld: /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:408: dberr_t dict_table_schema_check(const dict_table_schema_t*, char*, size_t): Assertion `table->cols[j].len < req_schema->columns[i].len' failed.
|
|
10.6.2 6c39eaeb126328e7813b146ecf652d51e4508981 (Debug)
|
Core was generated by `/test/MD120621-mariadb-10.6.2-linux-x86_64-dbg/bin/mysqld --no-defaults --core-'.
|
Program terminated with signal SIGABRT, Aborted.
|
#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:50
|
[Current thread is 1 (Thread 0x150ef88d7700 (LWP 212134))]
|
(gdb) bt
|
#0 __GI_raise (sig=sig@entry=6) at ../sysdeps/unix/sysv/linux/raise.c:50
|
#1 0x0000150efb495859 in __GI_abort () at abort.c:79
|
#2 0x0000150efb495729 in __assert_fail_base (fmt=0x150efb62b588 "%s%s%s:%u: %s%sAssertion `%s' failed.\n%n", assertion=0x55f3d7562948 "table->cols[j].len < req_schema->columns[i].len", file=0x55f3d7562778 "/test/10.6_dbg/storage/innobase/dict/dict0stats.cc", line=408, function=<optimized out>) at assert.c:92
|
#3 0x0000150efb4a6f36 in __GI___assert_fail (assertion=assertion@entry=0x55f3d7562948 "table->cols[j].len < req_schema->columns[i].len", file=file@entry=0x55f3d7562778 "/test/10.6_dbg/storage/innobase/dict/dict0stats.cc", line=line@entry=408, function=function@entry=0x55f3d7562878 "dberr_t dict_table_schema_check(const dict_table_schema_t*, char*, size_t)") at assert.c:101
|
#4 0x000055f3d700285f in dict_table_schema_check (req_schema=req_schema@entry=0x55f3d7b5ce80 <index_stats_schema>, errstr=errstr@entry=0x150ef88d34e0 "", errstr_sz=errstr_sz@entry=512) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:408
|
#5 0x000055f3d7005c34 in dict_stats_persistent_storage_check (caller_has_dict_sys_mutex=caller_has_dict_sys_mutex@entry=false) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:503
|
#6 0x000055f3d700d4ff in dict_stats_update (table=table@entry=0x150ea8022b08, stats_upd_option=DICT_STATS_FETCH_ONLY_IF_NOT_IN_MEMORY) at /test/10.6_dbg/storage/innobase/dict/dict0stats.cc:3529
|
#7 0x000055f3d6cc3cae in dict_stats_init (table=0x150ea8022b08) at /test/10.6_dbg/storage/innobase/include/dict0stats.ic:165
|
#8 ha_innobase::info_low (this=this@entry=0x150ea8027620, flag=flag@entry=282, is_analyze=is_analyze@entry=false) at /test/10.6_dbg/storage/innobase/handler/ha_innodb.cc:14262
|
#9 0x000055f3d6cc4d90 in ha_innobase::info (this=this@entry=0x150ea8027620, flag=flag@entry=282) at /test/10.6_dbg/storage/innobase/handler/ha_innodb.cc:14524
|
#10 0x000055f3d6ccc5fc in ha_innobase::open (this=0x150ea8027620, name=0x150ea8043360 "./test/t") at /test/10.6_dbg/storage/innobase/handler/ha_innodb.cc:5949
|
#11 0x000055f3d68d3ffb in handler::ha_open (this=0x150ea8027620, table_arg=table_arg@entry=0x150ea8021f68, name=0x150ea8043360 "./test/t", mode=mode@entry=2, test_if_locked=test_if_locked@entry=18, mem_root=mem_root@entry=0x0, partitions_to_open=0x0) at /test/10.6_dbg/sql/handler.cc:3285
|
#12 0x000055f3d6715815 in open_table_from_share (thd=thd@entry=0x150ea8000db8, share=share@entry=0x150ea8042dc0, alias=alias@entry=0x150ea80140f0, db_stat=db_stat@entry=33, prgflag=prgflag@entry=8, ha_open_flags=18, outparam=0x150ea8021f68, is_create_table=false, partitions_to_open=0x0) at /test/10.6_dbg/sql/table.cc:4307
|
#13 0x000055f3d65652f2 in open_table (thd=thd@entry=0x150ea8000db8, table_list=table_list@entry=0x150ea80140a8, ot_ctx=ot_ctx@entry=0x150ef88d5ab0) at /test/10.6_dbg/sql/sql_base.cc:2003
|
#14 0x000055f3d6569a22 in open_and_process_table (ot_ctx=0x150ef88d5ab0, has_prelocking_list=false, prelocking_strategy=0x150ef88d5c90, flags=0, counter=0x150ef88d5b4c, tables=0x150ea80140a8, thd=0x150ea8000db8) at /test/10.6_dbg/sql/sql_base.cc:3801
|
#15 open_tables (thd=thd@entry=0x150ea8000db8, options=@0x150ea8006620: {m_options = DDL_options_st::OPT_NONE}, start=start@entry=0x150ef88d5b38, counter=counter@entry=0x150ef88d5b4c, flags=flags@entry=0, prelocking_strategy=prelocking_strategy@entry=0x150ef88d5c90) at /test/10.6_dbg/sql/sql_base.cc:4284
|
#16 0x000055f3d656ab1f in open_and_lock_tables (thd=thd@entry=0x150ea8000db8, options=@0x150ea8006620: {m_options = DDL_options_st::OPT_NONE}, tables=<optimized out>, tables@entry=0x150ea80140a8, derived=derived@entry=true, flags=flags@entry=0, prelocking_strategy=prelocking_strategy@entry=0x150ef88d5c90) at /test/10.6_dbg/sql/sql_base.cc:5246
|
#17 0x000055f3d65b3d5f in open_and_lock_tables (flags=0, derived=true, tables=0x150ea80140a8, thd=0x150ea8000db8) at /test/10.6_dbg/sql/sql_base.h:509
|
#18 mysql_insert (thd=thd@entry=0x150ea8000db8, table_list=0x150ea80140a8, fields=@0x150ea8005fd8: {<base_list> = {<Sql_alloc> = {<No data fields>}, first = 0x55f3d7be3f80 <end_of_list>, last = 0x150ea8005fd8, elements = 0}, <No data fields>}, values_list=@0x150ea8006020: {<base_list> = {<Sql_alloc> = {<No data fields>}, first = 0x150ea8014ff0, last = 0x150ea8014ff0, elements = 1}, <No data fields>}, update_fields=@0x150ea8006008: {<base_list> = {<Sql_alloc> = {<No data fields>}, first = 0x55f3d7be3f80 <end_of_list>, last = 0x150ea8006008, elements = 0}, <No data fields>}, update_values=@0x150ea8005ff0: {<base_list> = {<Sql_alloc> = {<No data fields>}, first = 0x55f3d7be3f80 <end_of_list>, last = 0x150ea8005ff0, elements = 0}, <No data fields>}, duplic=DUP_ERROR, ignore=false, result=0x0) at /test/10.6_dbg/sql/sql_insert.cc:756
|
#19 0x000055f3d65fbd38 in mysql_execute_command (thd=thd@entry=0x150ea8000db8) at /test/10.6_dbg/sql/sql_parse.cc:4556
|
#20 0x000055f3d65e6890 in mysql_parse (thd=thd@entry=0x150ea8000db8, rawbuf=<optimized out>, length=<optimized out>, parser_state=parser_state@entry=0x150ef88d6400) at /test/10.6_dbg/sql/sql_parse.cc:8016
|
#21 0x000055f3d65f53fa in dispatch_command (command=command@entry=COM_QUERY, thd=thd@entry=0x150ea8000db8, packet=packet@entry=0x150ea800b769 "INSERT INTO t VALUES (0,0,36,'','','','')", packet_length=packet_length@entry=41, blocking=blocking@entry=true) at /test/10.6_dbg/sql/sql_class.h:1340
|
#22 0x000055f3d65f87da in do_command (thd=0x150ea8000db8, blocking=blocking@entry=true) at /test/10.6_dbg/sql/sql_parse.cc:1406
|
#23 0x000055f3d675cc8e in do_handle_one_connection (connect=<optimized out>, connect@entry=0x55f3d9a3f418, put_in_cache=put_in_cache@entry=true) at /test/10.6_dbg/sql/sql_connect.cc:1410
|
#24 0x000055f3d675d293 in handle_one_connection (arg=arg@entry=0x55f3d9a3f418) at /test/10.6_dbg/sql/sql_connect.cc:1312
|
#25 0x000055f3d6c0b166 in pfs_spawn_thread (arg=0x55f3d9927ab8) at /test/10.6_dbg/storage/perfschema/pfs.cc:2201
|
#26 0x0000150efb9a3609 in start_thread (arg=<optimized out>) at pthread_create.c:477
|
#27 0x0000150efb592293 in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:95
|
Bug confirmed present in:
MariaDB: 10.6.2 (dbg)
Bug (or feature/syntax) confirmed not present in:
MariaDB: 10.2.39 (dbg), 10.2.39 (opt), 10.3.30 (dbg), 10.3.30 (opt), 10.4.20 (dbg), 10.4.20 (opt), 10.5.11 (dbg), 10.5.11 (opt), 10.6.2 (opt)
MySQL: 5.5.62 (dbg), 5.5.62 (opt), 5.6.51 (dbg), 5.6.51 (opt), 5.7.34 (dbg), 5.7.34 (opt), 8.0.24 (dbg), 8.0.24 (opt)
|