前幾天一切正常,除了配置文件外,沒有對系統進行任何新更改。Salesforce:System.LimitException:太多的SOQL查詢:101
突然我得到這個錯誤信息:
Error: Invalid Data. Review all error messages below to correct your data.
Apex trigger generateUniqueBidId caused an unexpected exception, contact your administrator: generateUniqueBidId: System.LimitException: Too many SOQL queries: 101
trigger generateUniqueBidId on Bids__c (before insert) {
Map<String, String> profilePrefixMap = new Map<String, String>();
profilePrefixMap.put('Sales User', 'rds');
profilePrefixMap.put('Super User', 'rds');
profilePrefixMap.put('Standard User','SU');
profilePrefixMap.put('System Administrator','SysAdmin');
String defaultPrefix = ' ';
User user = [SELECT ProfileId FROM User Where Id = :Userinfo.getUserId() LIMIT 1];
Profile profile = [SELECT Name FROM Profile Where Id = :user.ProfileId LIMIT 1];
List<Bids__c> recentBids = [SELECT Id, CreatedById, Bid_unique_label__c From Bids__c WHERE Bid_unique_label__c = NULL];
/**Logics for updating old Bids with correct Bid_id. May be refactored away when all bids are updated
Could cause problems if trigger system becomes to complicated.
*/
for (Bids__c bid : recentBids){
String recentProfileName = [SELECT Profile.Name FROM User Where Id = :bid.CreatedById LIMIT 1].Profile.Name;
String bidId = profilePrefixMap.get(recentProfileName);
bid.Bid_unique_label__c = ((bidId == null) ? defaultPrefix : bidId);
}
upsert recentBids;
for (Bids__c bid : trigger.new){
String bidId = profilePrefixMap.get(String.valueOf(profile.Name));
bid.Bid_unique_label__c = ((bidId == null) ? defaultPrefix : bidId);
}
}
這解決了現在的錯誤消息。 我現在將繼續使用代碼。 – user2063927 2013-02-19 12:13:21
祝你好運,歡迎來到StackOverflow :) – eyescream 2013-02-19 12:30:20