AudienceSegmentServiceInterface audienceSegmentService =
dfpServices.get(session, AudienceSegmentServiceInterface.class);
// Create a statement to only select a specified first party audience
// segment.
StatementBuilder statementBuilder = new StatementBuilder()
.where("WHERE id = :audienceSegmentId and type = :type")
.orderBy("id ASC")
.limit(1)
.withBindVariableValue("audienceSegmentId", audienceSegmentId)
.withBindVariableValue("type", "FIRST_PARTY");
// Default for total result set size.
int totalResultSetSize = 0;
do {
// Get audience segments by statement.
AudienceSegmentPage page =
audienceSegmentService.getAudienceSegmentsByStatement(statementBuilder.toStatement());
if (page.getResults() != null) {
totalResultSetSize = page.getTotalResultSetSize();
int i = page.getStartIndex();
for (AudienceSegment audienceSegment : page.getResults()) {
System.out.printf(
"%d) Audience segment with ID \"%d\" and name \"%s\" will be populated.\n", i++,
audienceSegment.getId(), audienceSegment.getName());
}
}
statementBuilder.increaseOffsetBy(StatementBuilder.SUGGESTED_PAGE_LIMIT);
} while (statementBuilder.getOffset() < totalResultSetSize);
System.out.printf("Number of audience segments to be populated: %d\n", totalResultSetSize);
if (totalResultSetSize > 0) {
// Remove limit and offset from statement.
statementBuilder.removeLimitAndOffset();
// Create action.
PopulateAudienceSegments action = new PopulateAudienceSegments();
// Perform action.
UpdateResult result = audienceSegmentService.performAudienceSegmentAction(
action, statementBuilder.toStatement());
if (result != null && result.getNumChanges() > 0) {
System.out.printf("Number of audience segments populated: %d\n", result.getNumChanges());
} else {
System.out.println("No audience segments were populated.");