Hi TOM,
 We are planning on upgrading from Apex 22.1 to Apex 23.1.  We are currently on Oracle 19c using Apex 22.2:
SQL> 
SELECT * FROM v$version;
BANNER
--------------------------------------------------------------------------------
BANNER_FULL
----------------------------------------------------------------------------------------------------
BANNER_LEGACY                                                                             CON_ID
-------------------------------------------------------------------------------- ---------------
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.16.0.0.0
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production                         0
1 row selected.
SQL> 
SELECT * FROM apex_release;
VERSION_NO
----------------------------------------------------------------------------------------------------
API_COMPATIBILITY
----------------------------------------------------------------------------------------------------
PATCH_APPLIED
----------------------------------------------------------------------------------------------------
22.2.1
2022.10.07
APPLIED
1 row selected.
From what I read here: 
https://docs.oracle.com/en/database/oracle/apex/23.1/htmig/apex-installation-requirements.html#GUID-02BE4A34-B631-412C-8A82-EB92DABBACE0 it states "Oracle APEX release 23.1 requires an Oracle Database release 19c or later".  Based on the above query results and this statement, it would seem we are OK to upgrade, at least with regards to minimum Oracle Database release.
I have a question, though.  Our current compatible parameter is set to 12.1:
SQL> 
SELECT name, type, value FROM v$parameter WHERE name = 'compatible';
NAME                                                                                        TYPE
-------------------------------------------------------------------------------- ---------------
VALUE
----------------------------------------------------------------------------------------------------
compatible                                                                                     2
12.1.0.2.0
1 row selected.
Despite being on the minimum required Oracle DB release, would it be correct to assume we need to increase our compatible parameter setting?  I'm guessing yes.  If so, what is the minimum we can/should set it to?  I'm guessing no less than 19.0.0, but please confirm, especially since I'm wondering if a compatible parameter of 12.2 would work.
Thanks!
SQL*PLUS-kinda'-guy 
"compatible" is a setting for the datafile headers. It is setting the ability to downgrade to that release without needing to restore from backup, so it doesn't play a role in the features/options in the version of the database you're using.
I'm guessing you upgraded from 12.1 a while back, so you may as well bump up compatible to 19 during your next scheduled outage, assuming you never plan to go back to 12.1
And yes, you're good to go with APEX 23