Export the Results of a Saved File
This was an advanced task designed to fulfill a missing feature in Sumo.
With the catoperator you can simply retrieve your results and use the export feature.
Deprecated
Sumo Logic provides the ability to save a file using the save operator, but it does not allow you to export the results of that saved file. To do so, you'd have to re-run the original query and export the results.
But if you know you will need to export your saved files results routinely, you can create another column in the results that are saved to the file that acts as a primary key for each result. This key then allows you to conduct a lookup operation matching the key.
To create keys in your saved file:
In your query that is saving the file with the save operator, you need to add numbers to act as the primary key. You can start at 1 and increment by 1 for each result, as shown. Add a group by if needed (such as a timeslice):
| 1 as number
| accum number as number // by _timesliceNow that your saved file has numbers as unique keys on each result you can do a lookup so that the matching is done on the keys, like this:
| 1 as number
| accum number as key
| lookup * from shared/file.csv on key=numberThe query with the lookup operator needs to create at least the same number of keys as the results in your saved file, so that the keys match all. Since each result is assigned a key, you just need to make sure enough results are returned. If you have more keys from your lookup query, it is not a problem, because we don't match on them anyway. This will return all of your saved file's results, ready for export.
If you are appending to your saved file, you can get the file's last key to define the starting key for the append query using the following query:
| 1 as number
| accum number as key
| lookup _accum from shared/file/forsupport on key=_accum
| max(_accum)
| _max + 1 as keyThe
_accum
field is the same as thenumber
field in the first example. But you can't use this query with your save query that is appending because we use the max operator.