Tworzenie mapy tak:
Map<String, Schema.SObjectField> fldObjMap = schema.SObjectType.Account.fields.getMap();
List<Schema.SObjectField> fldObjMapValues = fldObjMap.values();
Następnie można wykonać iterację fldObjMapValues stworzyć ciąg kwerendy SOQL:
String theQuery = 'SELECT ';
for(Schema.SObjectField s : fldObjMapValues)
{
String theLabel = s.getDescribe().getLabel(); // Perhaps store this in another map
String theName = s.getDescribe().getName();
String theType = s.getDescribe().getType(); // Perhaps store this in another map
// Continue building your dynamic query string
theQuery += theName + ',';
}
// Trim last comma
theQuery = theQuery.subString(0, theQuery.length() - 1);
// Finalize query string
theQuery += ' FROM Account WHERE ... AND ... LIMIT ...';
// Make your dynamic call
Account[] accounts = Database.query(theQuery);
superfell jest prawidłowa, nie ma sposobu, aby bezpośrednio zrobić SELECT *. Jednak ten mały przepis na kod zadziała (cóż, nie testowałem go, ale wydaje mi się, że wygląda dobrze). Zrozumiałe, że Force.com chce architektury z wieloma dzierżawcami, w której zasoby są udostępniane tylko tak wyraźnie, jak to jest potrzebne - niełatwo, wykonując SELECT *, gdy zwykle potrzebny jest tylko podzbiór pól.
dzięki za odpowiedź. Czy mógłbybyś dzielić przykład, aby zbudować zapytanie z obiektu descriptionSObject. – Sukhhhh