在批量API 2.0查询中,如果不使用LIMIT子句,查询结果可能会被截断。这是因为批量API 2.0有一个默认的最大返回结果数限制。
为了解决这个问题,可以使用游标(cursor)来分页获取完整的结果。游标是一个指向结果集中某个位置的标记,它可以被用来获取下一页的结果。
下面是一个使用游标分页查询的示例代码:
from facebook_business import FacebookSession, FacebookAdsApi, Cursor
# 初始化API
access_token = ''
app_secret = ''
app_id = ''
session = FacebookSession(app_id, app_secret, access_token)
api = FacebookAdsApi(session)
# 创建一个批量查询
params = {
'fields': 'name, age',
'limit': 100 # 设置每页返回的数量
}
batch = api.new_batch()
# 第一次查询,获取第一页结果和游标
response = api.get('me/friends', params=params, api=batch)
friends = response.json()
cursor = response.next_cursor
# 使用游标继续查询
while cursor:
params['after'] = cursor # 设置游标参数
response = api.get('me/friends', params=params, api=batch)
friends += response.json()
cursor = response.next_cursor
# 打印所有查询结果
for friend in friends:
print(friend['name'], friend['age'])
在上述示例中,我们首先进行第一次查询,然后从响应中获取游标。然后,我们使用游标作为参数进行下一次查询,以获取下一页的结果。这个过程会一直循环,直到没有更多的结果为止。
请注意,每次查询返回的结果数量是有限制的,所以如果结果集非常大,可能需要多次查询才能获取到全部结果。