rtree/updateZipcode.c
{
RDM_CURSOR cursor = NULL;
POINTSOFINTEREST poi = {0};
POINTSOFINTEREST_LOCATION_KEY keyVal = {{0}};
RDM_RTREE_KEY key = {0};
/* Set the key value for the lookup */
keyVal.location[0] = -116.577610; /* Longitude is the 'x' value */
keyVal.location[1] = 43.529812; /* Latitude is the 'y' value */
keyVal.location[2] = -116.577610; /* Longitude is the 'x' value */
keyVal.location[3] = 43.529812; /* Latitude is the 'y' value */
/* Set key lookup information */
key.value = &keyVal;
/* Start an update transaction */
if (rc == sOKAY)
{
/* Get a cursor based on the r-tree key information */
db, KEY_POINTSOFINTEREST_LOCATION, &key, &cursor);
if (rc == sOKAY)
{
/* Move to the first (should be only) row in the cursor */
rc = rdm_cursorMoveToFirst (cursor);
if (rc == sOKAY)
{
/* Read the entire row */
rc = rdm_cursorReadRow (
cursor, &poi, sizeof (POINTSOFINTEREST), NULL);
/* Increase the maximum longitude/latitude, this zipcode will
now have a rectangle instead of just a point */
keyVal.location[2] =
-116.577620; /* Longitude is the 'x' value */
keyVal.location[3] = 43.529822; /* Latitude is the 'y' value */
/* Write the update row values to the database */
rc = rdm_cursorUpdateRow (
cursor, &poi, sizeof (POINTSOFINTEREST));
}
/* Free the cursor */
(void) rdm_cursorFree (cursor);
}
if (rc == sOKAY)
{
/* Commit the successful transaction */
rc = rdm_dbEnd (db);
}
else
{
/* Rollback the failed transaction */
(void) rdm_dbEndRollback (db);
}
}
return rc;
}
RDM_RETCODE rdm_cursorReadRow(RDM_CURSOR cursor, void *colValues, size_t bytesIn, size_t *bytesOut)
Read all columns from a row.
RDM_RETCODE rdm_dbGetRowsByKeyInRtreeKeyRange(RDM_DB db, RDM_KEY_ID keyId, const RDM_RTREE_KEY *keyValue, RDM_CURSOR *pCursor)
Associate an RDM_CURSOR with a row set based on a R-tree.
RDM_RETCODE rdm_dbEndRollback(RDM_DB db)
End and rollback a transactional operation.
RDM_RETCODE rdm_cursorUpdateRow(RDM_CURSOR cursor, const void *colValues, size_t bytesIn)
Update all columns in a row.
RDM_RETCODE rdm_dbStartUpdate(RDM_DB db, const RDM_TABLE_ID *writeTableIds, uint32_t numWriteTableIds, const RDM_TABLE_ID *readTableIds, uint32_t numReadTableIds, RDM_TRANS *pTrans)
Get write locks.