Named Views
This guide walks through configuring Gaffer to use Named Views and how to run them.
Named Views allow users to store a View in the cache, this can then be called on in OperationChains or in NamedOperations.
The benefit of using Named Views is that it allows you to store lengthy or complex Views that you can then re-use, i.e. run multiple different operations with the same filter applied.
Using Named Views
All Named Views are stored in a cache, so your first step should be to configure a suitable cache. For details on potential caches and how to configure them, see the Stores Guide.
Note
If you choose a non-persistent cache then any Named Views will be lost when you shut down your instance of Gaffer.
Named Views are enabled by default. To disable this feature the store property gaffer.store.namedview.enabled should be set to false.
There are three operations which manage Named Views.
These are AddNamedView, GetAllNamedViews and DeleteNamedView.
The examples below use the following graph:
graph LR
    A(["Person
        ID: John"])
    --
    "Created
     weight: 0.2"
    -->
    B(["Software
        ID: 1"])
    A
    --
    "Created
     weight: 0.6"
    -->
    C(["Software
        ID: 2"])Adding a NamedView
This example adds a NamedView that filters the data on the Created edge with a weight greater than 0.4.
final AddNamedView view = new AddNamedView.Builder()
    .name("exampleNamedView")
    .description("Example Named View")
    .overwrite(true)
    .view(new View.Builder()
        .edge("Created", new ViewElementDefinition.Builder()
            .preAggregationFilter(new ElementFilter.Builder()
                .select("weight")
                .execute(new IsMoreThan(0.4))
                .build())
            .build())
        .build()
    .build());
{
    "class" : "AddNamedView",
    "name" : "exampleNamedView",
    "description" : "Example Named View",
    "view": {
        "edges": {
            "Created": {
                "preAggregationFilterFunctions": [
                    {
                        "selection": [
                            "weight"
                        ],
                        "predicate": {
                            "class": "IsMoreThan",
                            "orEqualTo": false,
                            "value": {
                                "Float": 0.4
                            }
                        }
                    }
                ]
            }
        }
    },
    "overwriteFlag" : true
}
Using a NamedView
This executes the View within a GetElements operation.
Delete a NamedView
This removes the NamedView from the cache. Note that if you delete a Named View any Operation Chains or Named Operations which reference it will fail.