• Davi Arnaut's avatar
    Bug#36326: nested transaction and select · a9aaa09b
    Davi Arnaut authored
    The problem is that the query cache stores packets containing
    the server status of the time when the cached statement was run.
    This might lead to a wrong transaction status in the client side
    if a statement is cached during a transaction and is later served
    outside a transaction context (and vice-versa).
    
    The solution is to take into account the transaction status when
    storing in and serving from the query cache.
    
    mysql-test/r/innodb_cache.result:
      Update test case result.
    mysql-test/r/query_cache.result:
      Add test case result for Bug#36326
    mysql-test/t/query_cache.test:
      Add test case for Bug#36326
    sql/mysql_priv.h:
      Add new flags.
    sql/sql_cache.cc:
      Remember the transaction and autocommit status stored in the packet.
    tests/mysql_client_test.c:
      Add test case for Bug#36326
    a9aaa09b
sql_cache.cc 132 KB