Создайте карту следующим образом:
Map<String, Schema.SObjectField> fldObjMap = schema.SObjectType.Account.fields.getMap();
List<Schema.SObjectField> fldObjMapValues = fldObjMap.values();
Затем вы можете выполнить итерацию по fldObjMapValues, чтобы создать строку запроса 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 верно, нет прямого способасделать ВЫБОР *.Тем не менее, этот небольшой рецепт кода будет работать (ну, я не проверял его, но я думаю, что он выглядит хорошо).Понятно, что Force.com хочет использовать мультитенантную архитектуру, в которой ресурсы предоставляются только в случае явной необходимости - нелегко выполнить SELECT *, когда обычно требуется только подмножество полей.