mirror of
https://github.com/ansible-collections/community.mysql.git
synced 2025-04-05 10:10:32 -07:00
mysql_query: returns execution_time_ms list containing execution time per query
This commit is contained in:
parent
a45a0d006d
commit
43bdf89934
3 changed files with 31 additions and 2 deletions
|
@ -0,0 +1,2 @@
|
|||
minor_changes:
|
||||
- mysql_query - returns the `execution_time_ms` list containing execution time per query in milliseconds.
|
|
@ -62,7 +62,6 @@ author:
|
|||
- Andrew Klychkov (@Andersson007)
|
||||
extends_documentation_fragment:
|
||||
- community.mysql.mysql
|
||||
|
||||
'''
|
||||
|
||||
EXAMPLES = r'''
|
||||
|
@ -117,8 +116,18 @@ rowcount:
|
|||
returned: changed
|
||||
type: list
|
||||
sample: [5, 1]
|
||||
execution_time_ms:
|
||||
description:
|
||||
- A list containing execution time per query in milliseconds.
|
||||
- The measurements are done right before and after passing
|
||||
the query to the driver for execution.
|
||||
returned: success
|
||||
type: list
|
||||
sample: [7104, 85]
|
||||
version_added: '3.12.0'
|
||||
'''
|
||||
|
||||
import time
|
||||
import warnings
|
||||
|
||||
from ansible.module_utils.basic import AnsibleModule
|
||||
|
@ -139,6 +148,18 @@ DDL_QUERY_KEYWORDS = ('CREATE', 'DROP', 'ALTER', 'RENAME', 'TRUNCATE')
|
|||
# Module execution.
|
||||
#
|
||||
|
||||
|
||||
def execute_and_return_time(cursor, query, args):
|
||||
# Measure query execution time in milliseconds
|
||||
start_time = time.perf_counter()
|
||||
|
||||
cursor.execute(query, args)
|
||||
|
||||
# Calculate the execution time rounding it to 4 decimal places
|
||||
exec_time_ms = round((time.perf_counter() - start_time) * 1000, 4)
|
||||
return cursor, exec_time_ms
|
||||
|
||||
|
||||
def main():
|
||||
argument_spec = mysql_common_argument_spec()
|
||||
argument_spec.update(
|
||||
|
@ -213,6 +234,7 @@ def main():
|
|||
query_result = []
|
||||
executed_queries = []
|
||||
rowcount = []
|
||||
execution_time_ms = []
|
||||
|
||||
already_exists = False
|
||||
for q in query:
|
||||
|
@ -223,7 +245,8 @@ def main():
|
|||
category=mysql_driver.Warning)
|
||||
|
||||
try:
|
||||
cursor.execute(q, arguments)
|
||||
cursor, exec_time_ms = execute_and_return_time(cursor, q, arguments)
|
||||
execution_time_ms.append(exec_time_ms)
|
||||
except mysql_driver.Warning:
|
||||
# When something is run with IF NOT EXISTS
|
||||
# and there's "already exists" MySQL warning,
|
||||
|
@ -280,6 +303,7 @@ def main():
|
|||
'executed_queries': executed_queries,
|
||||
'query_result': query_result,
|
||||
'rowcount': rowcount,
|
||||
'execution_time_ms': execution_time_ms,
|
||||
}
|
||||
|
||||
# Exit:
|
||||
|
|
|
@ -35,6 +35,7 @@
|
|||
that:
|
||||
- result is changed
|
||||
- result.executed_queries == ['CREATE TABLE {{ test_table1 }} (id int)']
|
||||
- result.execution_time_ms[0] > 0
|
||||
|
||||
- name: Insert test data
|
||||
mysql_query:
|
||||
|
@ -52,6 +53,8 @@
|
|||
- result is changed
|
||||
- result.rowcount == [2, 1]
|
||||
- result.executed_queries == ['INSERT INTO {{ test_table1 }} VALUES (1), (2)', 'INSERT INTO {{ test_table1 }} VALUES (3)']
|
||||
- result.execution_time_ms[0] > 0
|
||||
- result.execution_time_ms[1] > 0
|
||||
|
||||
- name: Check data in {{ test_table1 }}
|
||||
mysql_query:
|
||||
|
|
Loading…
Add table
Reference in a new issue