SQCloudArrayValue
char *SQCloudArrayValue (SQCloudResult *result, uint32_t index, uint32_t *len);
Description
If the result of the function SQCloudResultType is RESULT_ARRAY then use this function to retrieve a pointer and a length for an array value.
Parameters
- result: A valid SQCloudResult pointer returned by an SQCloud function
- index: An array index (from 0 to SQCloudArrayCount-1)
- len: On output the length of the returned buffer
Return value
A pointer to the value.
Example
int main (int argc, const char * argv[]) {
// setup config
SQCloudConfig config = {0};
config.username = "myusername";
config.password = "mypassword"
SQCloudConnection *conn = SQCloudConnect("myproject.sqlite.cloud", SQCLOUD_DEFAULT_PORT, &config);
if (SQCloudIsError(conn)) {
printf("ERROR connecting: %s (%d)\n", SQCloudErrorMsg(conn), SQCloudErrorCode(conn));
return -1;
} else {
printf("Connection to host OK...\n\n");
}
// execute a TEST ARRAY command
SQCloudResult *r = SQCloudExec(conn, "TEST ARRAY;");
if (SQCloudResultType(r) == RESULT_ARRAY) {
int count = SQCloudArrayCount(r);
for (int i=0; i<count; ++i) {
SQCLOUD_VALUE_TYPE type = SQCloudArrayValueType(r, i);
switch (type) {
case VALUE_NULL: {
printf("NULL\n");
break;
}
case VALUE_INTEGER: {
int32_t value = SQCloudArrayInt32Value(r, i);
printf("%d\n", value);
// int64_t value = SQCloudArrayInt64Value(r, i);
// printf("%lld\n", value);
break;
}
case VALUE_FLOAT: {
float value = SQCloudArrayFloatValue(r, i);
printf("%f\n", value);
// double value = SQCloudArrayDoubleValue(r, i);
// printf("%f\n", value);
break;
}
case VALUE_BLOB:
case VALUE_TEXT: {
uint32_t len;
char *value = SQCloudArrayValue(result, i, &len);
if (type == VALUE_BLOB) printf("[%d] BLOB size %d\n", i, len);
else printf("[%d] %.*s\n", i, len, value);
}
}
}
}
SQCloudResultFree(r);
}