Nice article @Ben Schlanger !
I like how you're laying out the investigative process, though I think it's worth noting that every case is different and therefore recommendations also can differ. Especially the %NORUNTIME
hint should be used with caution as it may deprive you of better plans in most scenarios. In fact, we like to say that any time you have to revert to that hint, it's worth opening a case with the WRC as it should be an improvement opportunity for our engine to make that better choice automatically (available statistics permitting) :-)
Also, I'd like to advertise a few improvements we've made since the IRIS version shown here:
- Improved feedback in the query plan: we've been displaying a note in the query plan for a while now if there's a chance that different runtime parameter values may lead to a different plan, and as of IRIS 2023.3 are even calling out the specific predicates that drove the RTPC decision. For example, your plan may say "This query plan was selected based on the runtime parameter values that led to improved selectivity estimation of the range condition
enc.EncounterTime BETWEEN '2022-01-01' AND '2023-12-31'
" - Showing the actual runtime plan: Starting with IRIS 2023.3, we've enhanced the
EXPLAIN
and SMP utilities to no longer show the generic plan, after substituting out all parameter values, but the actual plan you'll get at runtime with the literal values you put in the query text. This addresses step #4 in the investigation described above. - SQL Process View: As of IRIS 2022.2, the Operations menu in the System Management Portal includes a "SQL Activity" link that leads you to a page listing all currently-running SQL statements, and allows you to drill through to the statement details and query plan. This also helps with step #4, and to identify any long-running queries in the first place. An aggregated form of this data is also available through the /api/metrics endpoint for consumption through a monitoring tool.
- Query and schema recommendations: In IRIS 2024.3, released last month, we've further expanded the information contained in the query plan from the RTPC related notes described above, to also include warnings on indices marked as non-selectable (cf investigation step #1), indices that are being ignored because they have non-matching collation, whether the plan is frozen, and similar additional information that may help you improve the statement text, schema, or overall system settings
The above features are all specifically introduced to help diagnose long-running queries more quickly and identify how things can be sped up, but of course these versions also include general performance enhancements and refinements to the RTPC infrastructure too, so it'll be exciting to see how fast this customer's query runs on the latest and greatest IRIS release!
Hi @Scott Roth , the %MANAGE_FOREIGN_SERVER privilege was only just introduced with 2024.2, as part of finalizing the full production support for Foreign Servers (see also release notes). I'm not sure though why it wouldn't appear after you created it. Can you confirm whether it's still there right after the CREATE SERVER command, whether you're using the same user for both connections, and whether or not you can CREATE FOREIGN TABLEs with that server (before logging off and / or after logging back in).
I understand upgrading may not be straightforward, but the most logical explanation would be that the initial, crude privilege checking (that we replaced in 2024.2 as advertised) has a hole in it.
thanks,
benjamin
data:image/s3,"s3://crabby-images/3d60e/3d60e544e7a8ad2e4dd41ddefb0e6cf3f0aeb8de" alt="Open Sesame!"
data:image/s3,"s3://crabby-images/4b61a/4b61a1276169a7fbcb09c5c9063036ced6cea11d" alt="1,000 Points"
data:image/s3,"s3://crabby-images/7a4a8/7a4a8648f0292119025809a0c41fd007a5fa1297" alt="Challenge Starter"
data:image/s3,"s3://crabby-images/40692/406920d43ab20aecef02691654642c8afad8dc89" alt="5,000 Points"
data:image/s3,"s3://crabby-images/a8411/a8411a82299d1b1362875bb92618e956189085e0" alt="Popular writer"
data:image/s3,"s3://crabby-images/d6a1e/d6a1e69ab66b6cbe1dcc5b371cd4d2c94f3a0671" alt="Blogger Badge"
data:image/s3,"s3://crabby-images/fd9e4/fd9e4ecb66baf34c491c2cb8dd66fd5ed5005611" alt="Reporter Badge"
Thanks for the excellent writeup @Ron Sweeney , and your neatly themed series is bound to inspire many to dive into the classic literature and/or tourism pond!!🤩