My query just got faster - brief introduction to 12.2 in-memory cursor duration temp tables
          Image courtesy of wikipedia             This post covers one of the new SQL performance enhancements that we incorporated into Database 12c Release 2 . All of these enhancements are completely automatic, i.e. transparent to the calling app/developer code/query. These features are enabled by default because who doesn’t want their queries running faster with zero code changes?   So in this post I am going to focus on the new In-Memory “cursor duration” temporary table  feature. Let’s start by looking at cursor duration temp tables…   Above image courtesy of wikimedia.org   What is a cursor duration temp table?  This is a feature that has been around for quite a long time. Cursor duration temporary tables (CDTs) are used to materialize intermediate results of a query to improve performance or to support complex multi step query execution. The following types of queries commonly use cursor duration temp tables:   WITH Clause  and parallel recursive WITH  Grouping Sets  S...