Represents the number of days assumed in one month if month justification or unjustifcation is performed. This is set to 30 for consistency with PostgreSQL. Note that this is means that month adjustments cause a year to be taken as 30 × 12 = 360 rather than 356/366 days.
Gets the number of days held in the instance. Note that this does not pay attention to a time component with -24 or less hours or 24 or more hours, unless JustifyDays has been called to produce this instance.
Gets the number of whole hours held in the instance. Note that this can be less than -23 or greater than 23 unless JustifyDays has been used to produce this instance.
Gets the number of months held in the instance. Note that this does not pay attention to a day component with -30 or less days or 30 or more days, unless JustifyMonths has been called to produce this instance.
The total number of ticks(100ns units) contained. This is the resolution of the NpgsqlInterval type. This ignores the number of days and months held. If you want them included use UnjustifyInterval first. The resolution of the PostgreSQL interval type is by default 1µs = 1,000 ns. It may be smaller as follows:
interval(0) - resolution of 1s (1 second)
interval(1) - resolution of 100ms = 0.1s (100 milliseconds)
interval(2) - resolution of 10ms = 0.01s (10 milliseconds)
interval(3) - resolution of 1ms = 0.001s (1 millisecond)
interval(4) - resolution of 100µs = 0.0001s (100 microseconds)
interval(5) - resolution of 10µs = 0.00001s (10 microseconds)
interval(6) or interval - resolution of 1µs = 0.000001s (1 microsecond)
As such, if the 100-nanosecond resolution is significant to an application, a PostgreSQL interval will not suffice for those purposes.
In more frequent cases though, the resolution of the interval suffices. NpgsqlInterval will always suffice to handle the resolution of any interval value, and upon writing to the database, will be rounded to the resolution used.
Returns a TimeSpan representing the time component of the instance. Note that this may have a value beyond the range ±23:59:59.9999999 unless JustifyDays has been called to produce this instance.
This absolute value of this instance. In the case of some, but not all, components being negative, the rules used for justification are used to determine if the instance is positive or negative.
Create a String representation of the NpgsqlInterval instance. The format returned is of the form: [M mon[s]] [d day[s]] [HH:mm:ss[.f[f[f[f[f[f[f[f[f]]]]]]]]]] A zero NpgsqlInterval is represented as 00:00:00 Ticks are 100ns, Postgress resolution is only to 1µs at most. Hence we lose 1 or more decimal precision in storing values in the database. Despite this, this method will output that extra digit of precision. It's forward-compatible with any future increases in resolution up to 100ns, and also makes this ToString() more applicable to any other use-case.