Home > Database > Mysql Tutorial > How to display system variables of MySQL server?

How to display system variables of MySQL server?

王林
Release: 2023-09-23 16:13:07
forward
997 people have browsed it

How to display system variables of MySQL server?

Use SHOW VARIABLES to display MySQL system variable values. This statement does not require any privileges. Just need to be able to connect to the server.

grammar

SHOW [GLOBAL | SESSION] VARIABLES
   [LIKE 'pattern' | WHERE expr]
Copy after login

The LIKE clause, if present, tells SHOW VARIABLES which variable names to match. To select rows based on broader criteria, use the WHERE clause.

SHOW VARIABLES accepts optional global or session variable scope modifications -

  • When GLOBAL is used as a modifier, this statement displays the value of the global system variable. For new connections to MySQL, these are the values ​​used to initialize the associated session variables. If a variable does not have a global value, the variable's value will not be displayed.

  • This statement displays the system variable values ​​that are valid for the current connection when using the SESSION modifier. If a variable has no session value, the variable's global value is displayed. SESSION is another way of saying LOCAL.

  • If no modifier is specified, it defaults to SESSION.

SHOW VARIABLES There are version-dependent display width limitations. Use SELECT as a workaround for variables with extremely long values ​​that are not fully displayed. For example -

SELECT @@GLOBAL.innodb_data_file_path;
Copy after login

Most system variables can be configured at server startup, although read-only variables like version_comment are an exception. Using the SET statement, a lot can be changed at runtime.

This is part of the output. The name and value list can be different for your server.

mysql> SHOW VARIABLES;
+--------------------------------------------+------------------------------+
| Variable_name                              | Value                        |
+--------------------------------------------+------------------------------+
| activate_all_roles_on_login                | OFF                          |
| auto_generate_certs                        | ON                           |
| auto_increment_increment                   | 1                            |
| auto_increment_offset                      | 1                            |
| autocommit                                 | ON                           |
| automatic_sp_privileges                    | ON                           |
| avoid_temporal_upgrade                     | OFF                          |
| back_log                                   | 151                          |
| basedir                                    | /usr/                        |
| big_tables                                 | OFF                          |
| bind_address                               | *                            |
| binlog_cache_size                          | 32768                        |
| binlog_checksum                            | CRC32                        |
| binlog_direct_non_transactional_updates    | OFF                          |
| binlog_error_action                        | ABORT_SERVER                 |
| binlog_expire_logs_seconds                 | 2592000                      |
| binlog_format                              | ROW                          |
| binlog_group_commit_sync_delay             | 0                            |
| binlog_group_commit_sync_no_delay_count    | 0                            |
| binlog_gtid_simple_recovery                | ON                           |
| binlog_max_flush_queue_time                | 0                            |
| binlog_order_commits                       | ON                           |
| binlog_row_image                           | FULL                         |
| binlog_row_metadata                        | MINIMAL                      |
| binlog_row_value_options                   |                              |
| binlog_rows_query_log_events               | OFF                          |
| binlog_stmt_cache_size                     | 32768                        |
| binlog_transaction_dependency_history_size | 25000                        |
| binlog_transaction_dependency_tracking     | COMMIT_ORDER                 |
| block_encryption_mode                      | aes-128-ecb                  |
| bulk_insert_buffer_size                    | 8388608                      |
| max_allowed_packet                         | 67108864                     |
| max_binlog_cache_size                      | 18446744073709547520         |
| max_binlog_size                            | 1073741824                   |
| max_binlog_stmt_cache_size                 | 18446744073709547520         |
| max_connect_errors                         | 100                          |
| max_connections                            | 151                          |
| max_delayed_threads                        | 20                           |
| max_digest_length                          | 1024                         |
| max_error_count                            | 1024                         |
| max_execution_time                         | 0                            |
| max_heap_table_size                        | 16777216                     |
| max_insert_delayed_threads                 | 20                           |
| max_join_size                              | 18446744073709551615         |
| thread_handling                            | one-thread-per-connection    |
| thread_stack                               | 286720                       |
| time_zone                                  | SYSTEM                       |
| timestamp                                  | 1530906638.765316            |
| tls_version                                | TLSv1.2,TLSv1.3              |
| tmp_table_size                             | 16777216                     |
| tmpdir                                     | /tmp                         |
| transaction_alloc_block_size               | 8192                         |
| transaction_allow_batching                 | OFF                          |
| transaction_isolation                      | REPEATABLE-READ              |
| transaction_prealloc_size                  | 4096                         |
| transaction_read_only                      | OFF                          |
| transaction_write_set_extraction           | XXHASH64                     |
| unique_checks                              | ON                           |
| updatable_views_with_limit                 | YES                          |
| version                                    | 8.0.12                       |
| version_comment                            | MySQL Community Server - GPL |
| version_compile_machine                    | x86_64                       |
| version_compile_os                         | Linux                        |
| version_compile_zlib                       | 1.2.11                       |
| wait_timeout                               | 28800                        |
| warning_count                              | 0                            |
| windowing_use_high_precision               | ON                           |
+--------------------------------------------+------------------------------+
Copy after login

When the LIKE clause is included, the statement displays only rows for variables whose names match the pattern. Use the LIKE clause (as shown) to get rows for a specific variable -

% is a wildcard character that can be used in a LIKE clause to get a list of variables whose names match the pattern:

SHOW VARIABLES LIKE '%auto%';
SHOW GLOBAL VARIABLES LIKE '%auto%';
Copy after login

Output

+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| auto_attach              | ON    |
| auto_increment_increment | 1     |
| auto_increment_offset    | 1     |
| auto_replicate           | OFF   |
| autocommit               | ON    |
+--------------------------+-------+
Copy after login
SHOW GLOBAL VARIABLES LIKE 'version%';
Copy after login

Output

+-------------------------+------------------------------+
| Variable_name           | Value                        |
+-------------------------+------------------------------+
| version                 | 5.1.16-beta                  | 
| version_comment         | MySQL Community Server (GPL) | 
| version_compile_machine | i686                         | 
| version_compile_os      | pc-linux-gnu                 | 
+-------------------------+------------------------------+
Copy after login

The pattern to match accepts wildcards anywhere. To match it literally, you should escape it since it is a wildcard character that matches any character. In practice, this is rarely necessary.

Using these commands, you can use MySQL to display all of its system variables. As mentioned before, no privileges are required to use them; all that is required is a connection to the database server.

The above is the detailed content of How to display system variables of MySQL server?. For more information, please follow other related articles on the PHP Chinese website!

source:tutorialspoint.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template