Tools
Here is a great tool for formating SQL:
Generates a select statement that selects all the fields from a chosen record.
Typically, when you use the %SelectAll, you would use a record object to store the results. That way you don’t have to know how many fields your result will return.
Examples
%SelectAll(JOB)
Local Record &myRecord;
&myRecord = CreateRecord(RECORD.MY_RECORD);
SQLExec(”%SelectAll(:1) WHERE MY_KEY = :2″, &myRecord, “My Key”, &myRecord);
Local Record &myInstallation;
&myRecord = CreateRecord(RECORD.INSTALLATION);
SQLExec(”%SelectAll(:1)”, &RECORD.INSTALLATION, &myInstallation);
%Table
Replaces with the actual table name of the given record.
Generally, this just means adding a “PS_” to the front of the record name. But, PeopleTools actually checks the alternate table name from the Record Type tab to see if a value is there first.
Two Uses:
Examples:
SELECT * FROM %Table(JOB) WHERE EMPLID = :1
SqlExec(”SELECT NAME FROM %Table(:1) WHERE EMPLID = :2″, Record.NAMES, &emplid, &name);
&sql = CreateSql(”SELECT * FROM %Table(:1) WHERE EMPLID = :2″, &MyRecord, &emplid);
INSERT INTO %Table(MYTEMP_TAO)
SELECT * FROM PS_MYDATATABLE
DateIn
Description
Converts a date into the form the database uses.
Used for:
Remember DateIn passes a date into the database.
DateOut
Description
Converts a date into the form that PeopleTools uses.
Used for:
Examples
SELECT %DateOut(MAX(EFFDT))
FROM PS_JOB
WHERE EMPLID = :1
AND EMPL_RCD = :2
AND EFFDT
INSERT INTO PS_MY_RNCTL(OPRID, RUN_CONTROL_ID, AS_OF_DATE)
VALUES(:1, :2, %DateIn(:3))
UPDATE PS_MY_TABLE
SET MY_DATE = %DateIn(:1)
WHERE MY_DATE