Tech Articles


Defining a PostgreSQL Database Profile in PB2019R3


PB2019R3
PostgreSQL v12 database


Summary:
   Ensure that the database properties are defined correctly for the PostgreSQL database in the DB Painter.

   If those properties are not defined correctly, the PB2019R3 IDE automatically creates the PB Catalog tables in the "public" schema every time it connects to the PostgreSQL (PG) database even if the catalog tables are already defined in the named "PowerBuilder Catalog Table Owner" schema.

 

Details:
In our Oracle schemas, we have the PB Catalog table owner specified as the superuser CHADBA.


Once created in Oracle, the catalog tables are in the CHADBA schema.


The PB IDE opens up smoothly with NO prompt to "Create the PowerBuilder catalog tables."

~~~~~~~~~~~

We are in the process of migrating to PostgreSQL (PG).
 - PG is case sensitive, and in our case all table and columns names are in lower case.
 - Note: Users can migrate to an UPPER or a LOWER case copy. Choose the LOWER case to eliminate a variety of
            issues.

Our PG development database also has the PB catalog tables defined in the chadba schema.
We set up the PG database mostly in the same way we set up the Oracle databases; chadba is in lowercase:






Defined in this manner, the IDE opens up smoothly and does not give you the "PB catalog tables not available" message.

- - - - - - - - - - -

If the setup is NOT done correctly, then when I open PB2019R3 and the connection is to my dev12c_PG database, PowerBuilder creates the complete set of catalog tables in the public schema, but does not populate either of the new the EDT or FMT catalog tables.

Thus when I get into the DB Painter and "select * from pbcatfmt;" the result set is empty. Why? Because the new set of tables defined in "public" are overriding the set of tables previously defined in "chadba".

I have to manually delete the public.pbcat* tables ....

drop table public.pbcatcol;
drop table public.pbcattbl;
drop table public.pbcatfmt;
drop table public.pbcatvld;
drop table public.pbcatedt;
commit;

.... before I have access to the FMT and EDT data again:

-- pbcattbl, pbcatcol, pbcatfmt, pbcatvld, pbcatedt
//drop table public.pbcatcol;
//drop table public.pbcattbl;
//drop table public.pbcatfmt;
//drop table public.pbcatvld;
//drop table public.pbcatedt;
//commit;

select * from pbcatfmt;

 

 

Comments (0)
There are no comments posted here yet

Find Articles by Tag

PowerServer Mobile DragDrop OLE Debugging Source Code Debug PBNI ActiveX IDE Resize DevOps SQL TreeView PowerBuilder (Appeon) SnapDevelop Application Authentication Filter BLOB Model Elevate Conference Git Oracle Text Database Table InfoMaker Windows 10 Icons Database Painter DataWindow Expression PBDOM PFC SqlExecutor Debugger Web Service Proxy Excel SVN Platform HTTPClient Performance JSONGenerator Open Source JSONParser Syntax API RibbonBar Interface PowerBuilder Compiler Encoding Android 64-bit Azure PDFlib Transaction Database Profile Linux OS DataWindow JSON Event Handling Database Object Error 32-bit Charts PDF File Design Deployment Encryption .NET Assembly Import Database Table Data Export C# TortoiseGit OrcaScript OAuth UI OAuth 2.0 TLS/SSL Event Icon Stored Procedure GhostScript PowerBuilder COM CI/CD Outlook TFS Database Connection RibbonBar Builder Mobile Event Handler JSON RichTextEdit Control PostgreSQL ODBC driver Class Window Database Testing Branch & Merge Web API .NET DataStore SqlModelMapper Menu WinAPI Import JSON Visual Studio License Automated Testing Repository External Functions WebBrowser Windows OS .NET Std Framework Migration Graph Authorization Data iOS SOAP REST SDK PowerScript (PS) UI Themes PowerServer Web PBVM Trial XML CoderObject SnapObjects SQL Server Variable MessageBox ODBC UI Modernization DataType Jenkins NativePDF Messagging Source Control PostgreSQL DLL Sort CrypterObject Array RESTClient Export JSON Bug Service Script Configuration Database Table Schema Installation Validation