diff options
author | Sergei Golubchik <serg@mariadb.org> | 2015-12-13 17:19:18 +0100 |
---|---|---|
committer | Sergei Golubchik <serg@mariadb.org> | 2015-12-13 17:19:18 +0100 |
commit | b418e978260777b88b7291db98682559212cb632 (patch) | |
tree | 07008bce5d661cc93dbeae3e322cca149cd4c02e /storage/perfschema | |
parent | 095b7b92d1d8ddf07d91a4f5917b9c052e403c68 (diff) | |
parent | 6bb292f1bc6781639533fbe0c681b1d86bb7ef3e (diff) | |
download | mariadb-git-b418e978260777b88b7291db98682559212cb632.tar.gz |
Merge branch 'merge/merge-perfschema-5.6' into 10.0
Diffstat (limited to 'storage/perfschema')
-rw-r--r-- | storage/perfschema/pfs.cc | 9 | ||||
-rw-r--r-- | storage/perfschema/pfs_events_statements.h | 6 | ||||
-rw-r--r-- | storage/perfschema/table_events_statements.cc | 33 | ||||
-rw-r--r-- | storage/perfschema/table_events_statements.h | 4 | ||||
-rw-r--r-- | storage/perfschema/unittest/pfs_server_stubs.cc | 1 |
5 files changed, 45 insertions, 8 deletions
diff --git a/storage/perfschema/pfs.cc b/storage/perfschema/pfs.cc index 58d766f480a..dd61df5f861 100644 --- a/storage/perfschema/pfs.cc +++ b/storage/perfschema/pfs.cc @@ -4388,6 +4388,8 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state, const void *charset) { DBUG_ASSERT(state != NULL); + DBUG_ASSERT(charset != NULL); + if (! flag_global_instrumentation) return NULL; PFS_statement_class *klass= find_statement_class(key); @@ -4432,6 +4434,8 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state, pfs->m_lock_time= 0; pfs->m_current_schema_name_length= 0; pfs->m_sqltext_length= 0; + pfs->m_sqltext_truncated= false; + pfs->m_sqltext_cs_number= system_charset_info->number; /* default */ pfs->m_message_text[0]= '\0'; pfs->m_sql_errno= 0; @@ -4511,6 +4515,7 @@ get_thread_statement_locker_v1(PSI_statement_locker_state *state, state->m_digest= NULL; state->m_schema_name_length= 0; + state->m_cs_number= ((CHARSET_INFO *)charset)->number; return reinterpret_cast<PSI_statement_locker*> (state); } @@ -4616,10 +4621,14 @@ static void set_statement_text_v1(PSI_statement_locker *locker, PFS_events_statements *pfs= reinterpret_cast<PFS_events_statements*> (state->m_statement); DBUG_ASSERT(pfs != NULL); if (text_len > sizeof (pfs->m_sqltext)) + { text_len= sizeof(pfs->m_sqltext); + pfs->m_sqltext_truncated= true; + } if (text_len) memcpy(pfs->m_sqltext, text, text_len); pfs->m_sqltext_length= text_len; + pfs->m_sqltext_cs_number= state->m_cs_number; } return; diff --git a/storage/perfschema/pfs_events_statements.h b/storage/perfschema/pfs_events_statements.h index b1e303e7021..d3fd79ea195 100644 --- a/storage/perfschema/pfs_events_statements.h +++ b/storage/perfschema/pfs_events_statements.h @@ -88,6 +88,12 @@ struct PFS_events_statements : public PFS_events ulonglong m_no_index_used; /** Optimizer metric, number of 'no good index used'. */ ulonglong m_no_good_index_used; + + /** True if sqltext was truncated. */ + bool m_sqltext_truncated; + /** Statement character set number. */ + uint m_sqltext_cs_number; + /** Statement digest. This underlying token array storage pointer is immutable, diff --git a/storage/perfschema/table_events_statements.cc b/storage/perfschema/table_events_statements.cc index 88dd3690067..c9d35540e21 100644 --- a/storage/perfschema/table_events_statements.cc +++ b/storage/perfschema/table_events_statements.cc @@ -337,9 +337,32 @@ void table_events_statements_common::make_row_part_1(PFS_events_statements *stat m_row.m_name= klass->m_name; m_row.m_name_length= klass->m_name_length; - m_row.m_sqltext_length= statement->m_sqltext_length; - if (m_row.m_sqltext_length > 0) - memcpy(m_row.m_sqltext, statement->m_sqltext, m_row.m_sqltext_length); + CHARSET_INFO *cs= get_charset(statement->m_sqltext_cs_number, MYF(0)); + size_t valid_length= statement->m_sqltext_length; + + if (cs->mbmaxlen > 1) + { + int well_formed_error; + valid_length= cs->cset->well_formed_len(cs, statement->m_sqltext, statement->m_sqltext + valid_length, + valid_length, &well_formed_error); + } + + m_row.m_sqltext.set_charset(cs); + m_row.m_sqltext.length(0); + m_row.m_sqltext.append(statement->m_sqltext, (uint32)valid_length, cs); + + /* Indicate that sqltext is truncated or not well-formed. */ + if (statement->m_sqltext_truncated || valid_length < statement->m_sqltext_length) + { + size_t chars= m_row.m_sqltext.numchars(); + if (chars > 3) + { + chars-= 3; + size_t bytes_offset= m_row.m_sqltext.charpos(chars, 0); + m_row.m_sqltext.length(bytes_offset); + m_row.m_sqltext.append("...", 3); + } + } m_row.m_current_schema_name_length= statement->m_current_schema_name_length; if (m_row.m_current_schema_name_length > 0) @@ -482,8 +505,8 @@ int table_events_statements_common::read_row_values(TABLE *table, f->set_null(); break; case 9: /* SQL_TEXT */ - if (m_row.m_sqltext_length) - set_field_longtext_utf8(f, m_row.m_sqltext, m_row.m_sqltext_length); + if (m_row.m_sqltext.length()) + set_field_longtext_utf8(f, m_row.m_sqltext.ptr(), m_row.m_sqltext.length()); else f->set_null(); break; diff --git a/storage/perfschema/table_events_statements.h b/storage/perfschema/table_events_statements.h index a42bbcb2e5a..6c8899e14c3 100644 --- a/storage/perfschema/table_events_statements.h +++ b/storage/perfschema/table_events_statements.h @@ -63,11 +63,9 @@ struct row_events_statements /** Length in bytes of @c m_source. */ uint m_source_length; /** Column SQL_TEXT. */ - char m_sqltext[COL_INFO_SIZE]; + String m_sqltext; /** Column DIGEST and DIGEST_TEXT. */ PFS_digest_row m_digest; - /** Length in bytes of @c m_info. */ - uint m_sqltext_length; /** Column CURRENT_SCHEMA. */ char m_current_schema_name[NAME_LEN]; /** Length in bytes of @c m_current_schema_name. */ diff --git a/storage/perfschema/unittest/pfs_server_stubs.cc b/storage/perfschema/unittest/pfs_server_stubs.cc index a8f417e390b..ec916865a7d 100644 --- a/storage/perfschema/unittest/pfs_server_stubs.cc +++ b/storage/perfschema/unittest/pfs_server_stubs.cc @@ -28,6 +28,7 @@ volatile bool ready_to_exit= false; uint lower_case_table_names= 0; CHARSET_INFO *files_charset_info= NULL; +CHARSET_INFO *system_charset_info= NULL; void compute_digest_md5(const sql_digest_storage *, unsigned char *) { |