Getting a List of Available Salesforce Objects
How do you determine what objects, specifically tables and columns, Salesforce makes available?
To get a list of tables, you use a special SOQL query using the command LIST TABLES. This query will return a list of table names; these names, in turn, can be subsequently used with LIST to retrieve the columns for each table. Here are some examples of the code to put this in action:
data:image/s3,"s3://crabby-images/9ebb8/9ebb88aed61e74ae33cf9a7023607de9228e912b" alt=""
As shown above, a simple data table and DataLayer.SQL element are used to retrieve a list of tables from Salesforce. The special SQL query syntax "LIST TABLES" is used in the datalayer's Source attribute.
data:image/s3,"s3://crabby-images/ab92b/ab92bba91f0281aa8b48a24869d88b64cf152d12" alt=""
The results returned from Salesforce can be accessed using the special Data token @Data.rdSalesforceTable~, as shown above,
data:image/s3,"s3://crabby-images/9f7cb/9f7cb80f5292fc9107c72b19da3e2868a13f4c0b" alt=""
and the output will look something like the example above.
Once the table names have been acquired, they can be used in a query to retrieve a list of the columns for a particular table.
data:image/s3,"s3://crabby-images/6a290/6a290e2b08231ee636bb9ac7d294402d19e4428b" alt=""
In the example above, a second data table is used to list the columns associated with one of the Salesforce tables. The SOQL query syntax is LIST <table name>, and in the example, a table name has been hard-coded into the query. A more sophisticated solution might use a table name selected from the displayed results of the previous (LIST TABLES) query to drive the second query, using a request token: LIST @Request.TableName~, for example.
data:image/s3,"s3://crabby-images/9a179/9a1796d6aa44b8213071b725180808e590635bc6" alt=""
And finally, as shown above, another special Data token @Data.rdSalesforceField~ is used to display the Salesforce table column information the query retrieved.
data:image/s3,"s3://crabby-images/f6494/f649443a25f8e6541ce2846963349829b7f662c9" alt=""
The output would be a list of columns, as shown above.
By combining the techniques shown here, developers can access data stored on Salesforce and incorporate it in their Logi applications.