GIF89a; Mini Shell

Mini Shell

Direktori : /usr/share/mysql-test/suite/perfschema/t/
Upload File :
Current File : //usr/share/mysql-test/suite/perfschema/t/misc.test

# Tests for PERFORMANCE_SCHEMA
# Miscelaneous

--source include/not_embedded.inc
--source include/have_perfschema.inc
--source include/no_protocol.inc

#
# Bug#12790483 OBJECTS_SUMMARY_GLOBAL_BY_TYPE AND RENAME TABLE
#
# Rename table leaves old tables names behind in
# performance_schema.objects_summary_global_by_type
#
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

CREATE TABLE test.t_before(a INT);
INSERT INTO test.t_before VALUES (1);

# The new table should appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE.

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

RENAME TABLE test.t_before TO test.t_after;

# The renamed table should appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE, but only
# after it is accessed.

SELECT COUNT(*) FROM test.t_after;

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

DROP TABLE test.t_after;

# The renamed table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE.

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

#
# Verify table views are ignored by the table io instrumentation.
#

CREATE TABLE test.t1(a INT);
INSERT INTO test.t1 VALUES (1);
CREATE VIEW test.v1 AS SELECT * FROM test.t1;
SELECT COUNT(*) FROM test.v1;

# Verify that a PFS table share was not created for the view.
SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

DROP VIEW test.v1;
DROP TABLE test.t1;

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';


#
# Bug#45496 Performance schema: assertion fails in
# ha_perfschema::rnd_init:223
#

--disable_result_log
SELECT EVENT_ID FROM performance_schema.events_waits_current
WHERE THREAD_ID IN
  (SELECT THREAD_ID FROM performance_schema.threads)
AND EVENT_NAME IN
  (SELECT NAME FROM performance_schema.setup_instruments
   WHERE NAME LIKE "wait/synch/%")
LIMIT 1;
--enable_result_log

#
# Bug#45088 Should not be able to create tables of engine PERFORMANCE_SCHEMA
#

--error ER_WRONG_PERFSCHEMA_USAGE
create table test.t1(a int) engine=performance_schema;

# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

#
# Bug#44897 Performance Schema: can create a ghost table in another database
#

--error ER_WRONG_PERFSCHEMA_USAGE
create table test.t1 like performance_schema.events_waits_current;

# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

#
# Bug#44898 PerformanceSchema: can create a table in db performance_schema, cannot insert
#

--error ER_TABLEACCESS_DENIED_ERROR
create table performance_schema.t1(a int);

# The table should not appear in OBJECTS_SUMMARY_GLOBAL_BY_TYPE

SELECT object_schema, object_name FROM performance_schema.objects_summary_global_by_type
  WHERE object_schema='test';

#
# Bug#51447 performance schema evil twin files
#

--disable_warnings
drop table if exists test.ghost;
--enable_warnings

create table test.ghost (a int, b int);
alter table test.ghost add index index_a(a);
alter table test.ghost add index index_b(b);
insert into test.ghost values (1, 3);
insert into test.ghost values (2, 4);
select * from test.ghost;

drop table test.ghost;

# Shoud return nothing
select * from performance_schema.file_instances
  where file_name like "%ghost%";

#
# Bug#52586 Misleading error message on attempt to access
#           a P_S table using a wrong name

--error ER_NO_SUCH_TABLE
select * from performance_schema.no_such_table;

#
# Bug#12370950 - 60905: TABLE_IO_WAITS_SUMMARY_BY_INDEX_USAGE AGGREGATES NON-INSERT DML WRONGLY
#

--disable_warnings
DROP TABLE IF EXISTS t_60905;
--enable_warnings
CREATE TABLE t_60905 (i INT, j INT, KEY(i)) ENGINE = InnoDB;
INSERT INTO t_60905 VALUES
(1,2), (3,4), (5,6), (7,8), (9,10);

# should delete with a "single" PRIMARY lookup (2 PRIMARY fetch, 1 PRIMARY delete)
DELETE FROM t_60905 WHERE i = 1;

# should delete with a full scan (5 NULL fetch, 1 NULL delete)
DELETE FROM t_60905 WHERE j = 8;

# show the instrument data
SELECT object_schema,
       object_name,
       index_name,
       count_fetch,
       count_insert,
       count_update,
       count_delete
  FROM performance_schema.table_io_waits_summary_by_index_usage
 WHERE object_schema = 'test'
   AND object_name = 't_60905';

DROP TABLE t_60905;


#
# Bug#11929832 - EVENTS_STATEMENTS_HISTORY HAS ERRORS=0 WHEN THERE ARE ERRORS
#
# Verify that SQL errors are properly counted.

use test;
truncate performance_schema.events_statements_history;
truncate performance_schema.events_statements_history_long;

--error ER_NO_SUCH_TABLE
select * from t1;

--echo 
select mysql_errno, returned_sqlstate, message_text, errors, warnings
  from performance_schema.events_statements_history where errors > 0;
  
--echo
select mysql_errno, returned_sqlstate, message_text, errors, warnings from 
  performance_schema.events_statements_history_long where errors > 0;

#
# Bug#20519832 - TRUNCATED SQL_TEXT values are not suffixed with '...'
#
# Verify that truncated SQL statements are suffixed with '...'

use performance_schema;
truncate performance_schema.events_statements_history;

# Should truncate at 1024 bytes (1024 characters)
select 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa' AS A;

# Should truncate at 1024 bytes (487 characters)

select _utf8mb4 'васÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑвасÑ' as B;

select count(*) from events_statements_history where sql_text like "%...";

./BlackJoker Mini Shell 1.0