Salesforce Visualforce中的Apex SOQL子查询
我正在研究在Visualforce页面中显示子查询SOQL查询。这是我的SOQL表达式Salesforce Visualforce中的Apex SOQL子查询,salesforce,apex-code,visualforce,soql,force.com,Salesforce,Apex Code,Visualforce,Soql,Force.com,我正在研究在Visualforce页面中显示子查询SOQL查询。这是我的SOQL表达式 public ApexPages.StandardSetController setCon { get { if(setCon == null) { setCon = new ApexPages.StandardSetController(Database.getQueryLocator( [SEL
public ApexPages.StandardSetController setCon {
get {
if(setCon == null) {
setCon = new ApexPages.StandardSetController(Database.getQueryLocator(
[SELECT Contact.Id, Opportunity.Id, Contact.FirstName, Contact.LastName, Contact.Phone,Contact.Account.Name, Contact.Email,Contact.Last_Contacted__c,Contact.Membership_Type__c,Opportunity.Call_Disposition__c, Opportunity.Sales_Stage__c,Opportunity.Name, Opportunity.CloseDate, Opportunity.StageName, Opportunity.CreatedDate FROM OpportunityContactRole where Opportunity.OwnerId=:Userinfo.getUserId()]));
}
return setCon;
}
set;
}
它收到一条消息“StandardSetController中不支持OpportunityContactRole”。所以我试着从帐户中获取机会和联系信息
因此,我的SOQL查询更改为:
SELECT Name, (SELECT Name, Phone, Email, Last_Contacted__c, Contact.Membership_Type__c FROM Account.Contacts) , (SELECT Call_Disposition__c, StageName, CreatedDate, CloseDate FROM Account.Opportunities) FROM Account where Id=:UserInfo.getUserId()])
但现在在我的Visualforce页面中,我无法访问子查询字段:
<apex:page controller="SalesRepPageControllerV3" tabstyle="contact" sidebar="false" showChat="true" >
<apex:form id="theForm">
<apex:sectionHeader title="Sales Rep Page for {!$User.FirstName}"/>
<apex:pageBlock id="innerblock" mode="edit">
<apex:pageMessages />
<apex:pageBlock id="innerblock">
<apex:pageBlockSection id="pagesection">
<apex:pageBlockTable value="{!ContactOpportunity}" var="co" id="pageblocktable">
<apex:column headerValue="Created Date" value="{!co.Opportunity.CreatedDate}"/>
<apex:column headerValue="First Name" value="{!co.Contact.FirstName}"/>
<apex:column headerValue="First Name" value="{!co.Contact.LastName}"/>
<apex:column headerValue="Phone" value="{!co.Contact.Phone}"/>
<apex:column headerValue="Account Name" value="{!co.Contact.Account.Name}"/>
<apex:column headerValue="Email" value="{!co.Contact.Email}"/>
<apex:column headerValue="Last Contacted" value="{!co.Contact.Last_Contacted__c}">
</apex:column>
<apex:column headerValue="Membership Type" value="{!co.Contact.Membership_Type__c}"/>
<apex:column headerValue="Call Disposition">
<apex:inputField value="{!co.Opportunity.Call_Disposition__c}"/>
</apex:column>
<apex:column headerValue="Sales Stage">
<apex:inputField value="{!co.Opportunity.Sales_Stage__c}"/>
</apex:column>
</apex:pageBlockTable>
</apex:pageBlockSection>
</apex:pageBlock>
<apex:pageBlockButtons >
<apex:commandButton value="Save" action="{!save}" reRender="pageblocktable"/>
<apex:commandButton value="Cancel" action="{!cancel}" reRender="pageblocktable"/>
</apex:pageBlockButtons>
</apex:pageBlock>
<apex:panelGrid columns="2">
<apex:commandLink action="{!previous}">Previous</apex:commandlink>
<apex:commandLink action="{!next}">Next</apex:commandlink>
</apex:panelGrid>
</apex:form>
</apex:page>
它不了解公司机会和公司联系人,因为它不是一个帐户。如果我将其更改为co.Opportunities或co.Contacts,则它是一个只能通过repeat访问的Arraylist
apex:repeat的问题是它没有我需要排序的列标题值。如果有人能帮忙,请告诉我怎么做。每个嵌套查询都有一个内部表。pageblocktable只能在单个表上迭代 遵循下面的代码示例。在帐户列表中选择您的帐户,然后使用一个pageblocktable和两个嵌套的pageblocktable在列表中迭代 控制器
public List<Account> _accounts;
public list<Account> Accounts {
get {
if (_accounts == null) {
_accounts = [SELECT Name, (SELECT Name, Phone, Email, Last_Contacted__c, Contact.Membership_Type__c FROM Account.Contacts) , (SELECT Call_Disposition__c, StageName, CreatedDate, CloseDate FROM Account.Opportunities) FROM Account where Id=:UserInfo.getUserId()];
}
return _accounts;
}
}
视觉力
<apex:pageBlockTable value="{!Accounts}" var="acc" id="pageblocktable">
<apex:column headerValue="Account Name" value="{!acc.Name}"/>
<apex:pageBlockTable value="{!acc.Opportunities}" var="ops" id="opportunities">
<apex:column headerValue="Created Date" value="{!ops.CreatedDate}"/>
<apex:column headerValue="Call Disposition">
<apex:inputField value="{!ops.Call_Disposition__c}"/>
</apex:column>
<apex:column headerValue="Sales Stage">
<apex:inputField value="{!ops.Sales_Stage__c}"/>
</apex:column>
</apex:pageBlockTable>
<apex:pageBlockTable value="{!acc.Contacts}" var="con" id="contacts">
<apex:column headerValue="First Name" value="{!con.FirstName}"/>
<apex:column headerValue="First Name" value="{!con.LastName}"/>
<apex:column headerValue="Phone" value="{!con.Phone}"/>
<apex:column headerValue="Account Name" value="{!con.Account.Name}"/>
<apex:column headerValue="Email" value="{!con.Email}"/>
<apex:column headerValue="Last Contacted" value="{!con.Last_Contacted__c}" />
<apex:column headerValue="Membership Type" value="{!con.Membership_Type__c}"/>
</apex:pageBlockTable>
</apex:pageBlockTable>
大量编辑
我不认为你可以使用一个标准的控制器。使用自定义控制器,我能够获得当前用户的opportunity contacts的合并列表:
第页:
控制器:
public with sharing class TestQueryController {
List<OpportunityContactRole> myOCR;
public List<OpportunityContactRole> getOpportunities() {
if (myOCR == null) {
myOCR = [SELECT Contact.Id, Opportunity.Id, Contact.FirstName, Contact.LastName, Contact.Phone,
Contact.Account.Name, Contact.Email, Opportunity.Name,
Opportunity.CloseDate, Opportunity.StageName, Opportunity.CreatedDate
FROM OpportunityContactRole where Opportunity.OwnerId=:Userinfo.getUserId()];
}
return myOCR;
}
}
您需要在自定义字段中替换。如果需要排序,给出了一种方法,不过使用包装器类和Apex接口可能可以避免重复访问数据库。最后,您需要实现自己的保存逻辑。祝你好运 非常感谢,杰拉德!我会尝试它,并回答,如果我仍然有问题。嗨杰拉德出于某种原因,它只是显示我的帐户名字段和其他非字段。你知道为什么吗?不客气。。。如果它对你有效,请向上投票并将其标记为答案。它有效,但我希望将联系人和机会放在一个页面块表中,然后我可以对其进行排序。这有可能吗?有没有其他的替代方法呢?我在你的问题中看到了你的实际需求-我专注于让Gerard的代码工作。把它留给我吧——我会考虑如何做,也许下周会发布一些东西。嘿,谢谢你们,我只能在Workbench上测试查询,但是可视化的force代码。这是一种假设,即嵌套块可以工作。VisualForce编程的一半是猜测,不是吗!嗨,帕特,感谢您的回复,一个解决方案将是伟大的,因为我需要在下周交付这个项目。我还需要能够保存对inputfield所做的更改。当我从帐户对opportunity和contact进行内部SOQL查询时,调用setcon.save时,它似乎不想保存更改,其中setcon的类型为ApexPages.StandardSetController。
public with sharing class TestQueryController {
List<OpportunityContactRole> myOCR;
public List<OpportunityContactRole> getOpportunities() {
if (myOCR == null) {
myOCR = [SELECT Contact.Id, Opportunity.Id, Contact.FirstName, Contact.LastName, Contact.Phone,
Contact.Account.Name, Contact.Email, Opportunity.Name,
Opportunity.CloseDate, Opportunity.StageName, Opportunity.CreatedDate
FROM OpportunityContactRole where Opportunity.OwnerId=:Userinfo.getUserId()];
}
return myOCR;
}
}