Oracle Application Express
Oracle Application Express (APEX) è un framework sviluppato da Oracle, pensato per lo sviluppo di siti web data-oriented e basato sull'infrastruttura fornita dal database Oracle. Salesforce APEX è tutto ciò che segue: un linguaggio OOP (programmazione orientata agli oggetti) molto simile a Java per lo sviluppo rapido di applicazioni web. DescrizioneLa tecnologia Apex in Salesforce è una tecnologia che consente il building di applicazioni web in modo davvero rapidissimo. Tale linguaggio e le API sono fornite nativamente nel CRM Salesforce in piattaforma PaaS (Platform as a Service) chiamata Force.com. La piattaforma Force.com è inclusa nell'org Salesforce e permette l'implementazione del codice Apex sia in un ambiente dev(di sviluppo) chiamato Develop Console incluso o separatamente in un IDE(Integrated Development Environment) come Eclipse, Visual Studio code ed altri mediante l'aggiunta del plugin Force.com IDE.[1] L'approccio di sviluppo è chiamato RAD(Rapid application Development) come per fare un paragone avviene con le pagine web costruite medianti le tecnologie JAVA EE, vedi jsf o jsp. Il codice Apex è completamente memorizzato, compilato ed eseguito in Cloud pertanto non necessita di alcuna risorsa in locale come framework ecc. Il codice viene eseguito in piattaforma Force.com o Lightning a seconda della tecnologia utilizzata. La sintassi dell'Apex è JAVA like tanto da considerarlo un derivato di Oracle Java, anche se ci sono molte differenze e sicuramente a vantaggio dell'Apex oltre al completo uso in Cloud abbiamo sicuramente un modo di performare il manage dei dati negli oggetti del Database sicuramente molto più efficiente di qualsiasi altra tecnologia grazie alle API fornite dal linguaggio. In pratica il mappaggio dell'ORM che con altre tecnologie è realizzabile per mezzo di framework come Hibernate ed eclipseLink per Java con svariate righe di codice di logica applicativa qui in Apex è pressoché immediato e realizzato con semplici statement come se le tabelle del database e gli oggetti gestiti dall'ambiente di sviluppo fossero già mappati. Caratteristiche
La piattaforma Lightning è un framework su server che permette la compilazione, memorizzazione ed esecuzione di codice Apex. Caratteristiche del linguaggio
ArrayIl linguaggio ci mette a disposizione gli array che sono vettori contenenti elementi sia di tipo primitivo che oggetti ma ogni array rappresenta sempre un elenco di tipi omogenei. Esempio come vediamo di seguito io posso dichiarare un array di stringhe e aggiungerne di nuove ma non posso aggiungergli un tipo diverso dal String. String[] arrayString ; //dichiarazione
arrayString = new String[]();
//se invece conosco già la size il contenuto posso anche inizializzarlo in fase di instanziazione nel seguente modo.
arrayString = new String[4]{ 'guardate', 'come istanzio', 'questo array', 'di String'};
per l'accesso in lettura o scrittura distruttiva poi basterà usare uno dei loop che più avanti vi mostrerò. ClassiOra andiamo a vedere un esempio per comprendere meglio i semplici concetti visti sopra: //sintassi dichiarazione classe
public class myFirstClassApex {
Double weight = 84.90;
Integer age = 37;
Boolean married = false;
String name = "Generoso";
Integer idPearson = 123;
}
CollectionsTroviamo in Apex le collezioni di oggetti seguenti:
List<Integer> distance = new List<Integer>();
//operazioni basiche add, get, set, clear l’accesso avviene con indice...
Esempio: distance.add(100);
distance.get(0);
distance.set(0,200);
//cancella tutto
distance.clear();
// ordinamento
distance.sort();
Set<Double> setdistance = new Set<Double>();
// non ammette duplicati, le operazioni sono add, remove ecc..
Esempio:
Map<Id,String> myMap = new Map<Id,String>();
// è una coppia chiave valore
La mappa può essere inizializzata nel seguente modo: Map<String,String> myMap = new Map<String,String>{"name"=>"Generoso", "Matter" => "Apex programming" }
Le operazioni principali sono get e put come nel seguente esempio: myMap.put('job', 'employee');
myMap.get('job');
Costrutti condizionaliI costrutti decisionali sono: {if-else} , {switch}.
if (condizione booleana è true){
esecuzione di una lista di statements;
}
else{
lista ancora di actions;
}
Ad esempio se mia moglie è incinta io voglio festeggiare altrimenti voglio solo bere latte: // my_wife _state è una stringa.
if (my_wife_state == 'pregnant') {
word = "urrà Andiamo al mio pub preferito!";
}
else {
word = "Noo cavolo mi bevo una bottiglia di latte!";
}
System.debug(word);
Costrutti IterativiPer sviluppare nel linguaggio abbiamo poi necessità dei costrutti iterativi che sono:
Esempio for: for (int counter = 0; counter < distance.size(); counter++)
System.debug(distance.get(counter));
//oppure ancora for
for (String myWord: arrayString) {
if(myWord.equals('guardate')
System.debug('This is positions index zero');
}
// while
Integer counter = 0;
while (counter < distance.size()) {
System.debug(distance.get(counter));
counter++;
}
// do while
Integer counter = 0;
do {
System.debug(distance.get(counter));
counter++;
}
while(counter < distance.size());
Ricapitolando nel linguaggio Apex esistono le classi (I tipi), i trigger (una o più actions generate a seguito di un evento, ad esempio l’inserimento di un record e queste actions possono essere eseguite prima o dopo l’inserimento, un aggiornamento o una cancellazione, troviamo i tipi primitivi (Integer, Double ecc…), le interfacce, le classi sharing o without sharing. I TriggersQuando parliamo di trigger ci riferiamo ad uno script di codice Apex realizzabile in più modi da piattaforma Salesforce il quale abilita l'utente ad eseguire delle Actions customizzate prima o dopo il verificarsi di eventi, lo script è autonomo e la parola richiama senza ombra di dubbio i trigger usati nei database(concetto analogo). Gli eventi che possono scatenare il trigger sono i parametri del trigger stesso e sono elencati di seguito:
Per gestire gli attributi dei record oggetto del trigger si usano delle variabili speciali chiamate di contesto, una delle quali è specificata nell'esempio dopo. Le variabili di contesto sono tutte in seguito:
Vediamolo ora da vicino in che modo esso viene scatenato. // Codice trigger
trigger triggerNameIdentificator on recordType(before insert, after insert, before update, after update, before delete, after delete) {
for(recordType variableSupport: Trigger.New) {
if(variableSupport.fieldName == 'patternChoosedByMe') {
System.debug('Set Off any Actions in this block ');
}
}
}
Per definire variabili e costanti, abbiamo il contesto statico legato alla classe e molto altro. Salesforce DatabaseLa Potenza di questo linguaggio risiede nella possibilità di compilare, salvare e eseguire tutto on cloud su server Salesforce in piattaforma Lightning, esso quindi non richiede spazio in memoria ne installazioni di software oltre al grande beneficio che permette la costruzione di applicazioni con connessione nativa al database Oracle che si concretizza con invocazione diretta di script SOQL o SOSL. Ogni interrogazione e modifica del modello dati avviene per mezzo di un linguaggio DML(Data Manipulation Language) i cui statement sono i seguenti:
La gestione dei record nel database può avvenire o per mezzo del DML solo o mediante l'oggetto Database. Un semplicissimo esempio statement DML lanciato senza l'uso dell'oggetto database è il seguente: insert new Account(Name='accountName');
Le query vengono performate per mezzo di due linguaggi di interrogazione il Salesforce Object Query Language(SOQL) e il Salesforce Object Search Language(SOSL). Le differenze sostanziali sono che il primo è usato per query su un solo tipo di tabella e non ammette interrogazioni troppo complesse come la join ma è più usato mentre il secondo è usato per recuperare dati da più record contemporaneamente e supera le limitazioni dell'altro quando non si ha certezza sui campi da recuperare e i dati sono più tabelle. Con SOQL le command sono un sottoinsieme dell'SQL ma performate per sole SELECT di lettura che non ammette il simbolo jolly '*' mentre inserimenti, aggiornamenti e cancellazioni vengono realizzati solo pe rmezzo di DML puro. In SOSL le query sono delle FIND che si scostano dalla sintassi SQL e usate per il retrieve(recupero) di dati da più tabelle in contemporaneo. Per esempio le query Select per leggere nel database i campi della tabella persone è così: person[] persons = [SELECT * FROM person];
// array di oggetti del tipo person.
NoteVoci correlateCollegamenti esterni
|