Community Tip - Did you get called away in the middle of writing a post? Don't worry you can find your unfinished post later in the Drafts section of your profile page. X
Hello,
I have a strange behavior of QueryPropertyHistory when i try to test it on thingworx services. Im a newbies so i may miss some core functionality of this function.
Here is my code:
var query = {
filters: {
type: "LIKE",
fieldName: "MSN",
value: MSN
}
};
// result: INFOTABLE dataShape: ""
var result = me.QueryPropertyHistory({
oldestFirst: OldestFirst /* BOOLEAN */,
maxItems: MaxItems /* NUMBER */,
endDate: EndDate /* DATETIME */,
query: query /* QUERY */,
startDate: StartDate /* DATETIME */
});
I try to fetch properties values from the thing used en second time to generate statistics:
the thing store data on valustream database.
Scenario:
1- I run this test (1.JPG)
As you can see there is rows returned ans there is data on the date 10/30/2019 : 5:30 pm.
2-Now let's do the same test but we change the start date to the current day
Result : (No data)
The first screenshot show that i have data in this date but when i filter the date i got no rows!
I have no explanation for this ?
Can you help me please.
Many thanks.
Solved! Go to Solution.
Hello,
I'm not sure what exactly happens inside your QueryPropertiesHistory, so I can only guess that this information will be useful to understand the source of your problem:
QueryPropertyHistory extrapolates data points. So if you have 2 subsequent changes like this:
thing.property1 = 'first'; // At 08:00
thing.property2 = 'second'; // At 08:10
Then when querying for all properties it will take all timestamps and interpolate the values as if they were set at that moment (it will use the last known value):
Timestamp | property1 | property2 |
08:00 | first | ? |
08:10 | first | second |
All this interpolation happens inside the Query service, in the database it only stores two events. It's easy to see if you query it via QueryNumericPropertyHistory, which doesn't interpolate values and return them as in the database.
I hope it helps. Otherwise provide the code for this QueryPropertiesHistory, so that we can take a look.
/ Constantine
Hello,
I'm not sure what exactly happens inside your QueryPropertiesHistory, so I can only guess that this information will be useful to understand the source of your problem:
QueryPropertyHistory extrapolates data points. So if you have 2 subsequent changes like this:
thing.property1 = 'first'; // At 08:00
thing.property2 = 'second'; // At 08:10
Then when querying for all properties it will take all timestamps and interpolate the values as if they were set at that moment (it will use the last known value):
Timestamp | property1 | property2 |
08:00 | first | ? |
08:10 | first | second |
All this interpolation happens inside the Query service, in the database it only stores two events. It's easy to see if you query it via QueryNumericPropertyHistory, which doesn't interpolate values and return them as in the database.
I hope it helps. Otherwise provide the code for this QueryPropertiesHistory, so that we can take a look.
/ Constantine
I agree with @Constantine analysis.
Probably there was no value logged between 12:00 am and 5:30 pm on 30-Oct.
The values shown on 1.JPG during this period are probably interpolated - you can validate using the Query<BASETYPE>PropertyHistory service - this service does not perform interpolation and returns logged value only.