The following post talks about running a query to return Files related to a specific record:
How to query all files attached to the Opportunity
What I'm trying to do is return ALL files related to an object (Events in this case). I tried the following query, but it returned an error that indicates that I need to include all of the record id's that I want it to look through (which could be millions). I just want the query to return the results based on the associated object, without having to put in individual record id's
SELECT ContentDocumentId,Id,LinkedEntityId FROM ContentDocumentLink WHERE LinkedEntityId LIKE '00U%'
Here's the error I received:
MALFORMED_QUERY: Implementation restriction: ContentDocumentLink requires a filter by a single Id on ContentDocumentId or LinkedEntityId using the equals operator or multiple Id's using the IN operator.
Best Answer
ContentDocumentLink
, as you can see from that error message, has very strict requirements on how you can query it. You must supply a literal Id value or a set of Id values.This is a major limitation. The only way I have found around it for very broad-based or global queries like the one you're interested in is a two-stage process off-platform with some Python glue to construct
ContentDocumentLink
queries. (If there is a better solution, I would love to hear about it!)You may be able to do something similar in an Apex batch job depending on what you're hoping to do with these files/
ContentDocumentLink
s.First, you'd use a report, or Workbench Bulk API job, to pull the full list of Ids of Events in your organization. Then you take that huge list of Ids and paste it into a Python script, as below. (Note that this requires the superb
simple_salesforce
module, which I use for this kind of glue-API-scripting all the time).What this script does is iterate over the arbitrarily-large set of Ids you provide it and construct
ContentDocumentLink
queries by batching those Ids into groups as large as allowed by the platform. It saves theContentDocumentLink
data in CSV format on standard output.