-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathCreateExampleAsync.cs
42 lines (40 loc) · 1.72 KB
/
CreateExampleAsync.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
using NRedisTimeSeries.DataTypes;
using NRedisTimeSeries.Commands.Enums;
using StackExchange.Redis;
using System.Collections.Generic;
using System.Threading.Tasks;
namespace NRedisTimeSeries.Example
{
/// <summary>
/// Examples for NRedisTimeSeries async API for creating new time series.
/// </summary>
internal class CreateAsyncExample
{
/// <summary>
/// Simple time-series creation.
/// </summary>
public static async Task SimpleCreateAsync()
{
ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
IDatabase db = redis.GetDatabase();
await db.TimeSeriesCreateAsync("my_ts");
redis.Close();
}
/// <summary>
/// Examples for creating time-series with parameters.
/// The parameters retentionTime, uncompressed and labels are optional and can be set in any order when used as named argument.
/// </summary>
public static async Task ParameterizedCreateAsync()
{
ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("localhost");
IDatabase db = redis.GetDatabase();
await db.TimeSeriesCreateAsync("retentionTime_ts", retentionTime: 5000);
await db.TimeSeriesCreateAsync("uncompressed_ts", uncompressed: true);
var label = new TimeSeriesLabel("key", "value");
var labels = new List<TimeSeriesLabel> { label };
await db.TimeSeriesCreateAsync("labeled_ts", labels: labels);
await db.TimeSeriesCreateAsync("parameterized_ts", labels: labels, uncompressed: true, retentionTime: 5000, duplicatePolicy: TsDuplicatePolicy.LAST);
redis.Close();
}
}
}