From a5d4acc5e0884621099a94d90b4f9013b2953d22 Mon Sep 17 00:00:00 2001 From: Andrew Gene Brown Date: Thu, 18 Apr 2024 14:18:09 -0700 Subject: [PATCH 1/2] SDA_spatialQuery: implement `what` `'mupoint'`, `'muline'`, `'featpoint'`, `'featline'` for #342 --- R/SDA-spatial.R | 93 +++++++++++++++++++++++-------------------------- 1 file changed, 43 insertions(+), 50 deletions(-) diff --git a/R/SDA-spatial.R b/R/SDA-spatial.R index 4509edde..4f6e5ea7 100644 --- a/R/SDA-spatial.R +++ b/R/SDA-spatial.R @@ -331,9 +331,9 @@ SDA_spatialQuery <- function(geom, what <- "mupolygon" } - # sanity checks - if (!what %in% c('mukey', 'mupolygon', 'areasymbol', 'sapolygon')) { - stop("query type (argument `what`) must be either 'mukey' / 'areasymbol' (tabular result) OR 'mupolygon' / 'sapolygon' (geometry result)", call. = FALSE) + # determine if requested data type is allowed + if (!what %in% c('mukey', 'mupolygon', 'mupoint', 'muline', 'featpoint', 'featline', 'areasymbol', 'sapolygon')) { + stop("query type (argument `what`) must be either 'mukey' / 'areasymbol' (tabular result) OR 'mupolygon', 'mupoint', 'muline', 'featpoint', 'featline', 'sapolygon' (geometry result)", call. = FALSE) } # areasymbol is allowed with db = "SSURGO" (default) and db = "SAPOLYGON" @@ -363,8 +363,12 @@ SDA_spatialQuery <- function(geom, wkt <- wk::wk_collection(wk::as_wkt(geom)) # returning geom + mukey or geom + areasymbol - if (what %in% c('mupolygon', 'sapolygon')) { + if (what %in% c("mupolygon", "sapolygon", "mupoint", "muline", "featpoint", "featline")) { + if (what %in% c("mupoint", "muline", "featpoint", "featline")) { + geomAcres <- FALSE + } + # return intersection + area if (geomIntersection) { @@ -379,6 +383,13 @@ SDA_spatialQuery <- function(geom, .template <- .SDA_geometrySelector(db = db, method = 'overlap', geomAcres = geomAcres) q <- sprintf(.template, as.character(wkt)) } + + if (db == "SSURGO" && what %in% c("mupoint", "muline", "featpoint", "featline")) { + q <- gsub("mupolygon", what, q) + if (what %in% c("featpoint", "featline")) { + q <- gsub("mukey", "featkey", q) + } + } if (query_string) { return(q) @@ -388,7 +399,7 @@ SDA_spatialQuery <- function(geom, # note that row-order / number of rows in results may not match geom res <- suppressMessages(SDA_query(q)) - if (inherits(res, 'try-error')) { + if (is.null(res) || inherits(res, 'try-error')) { return(res) } @@ -397,58 +408,40 @@ SDA_spatialQuery <- function(geom, # sf -> terra res <- terra::vect(res) } - } - - if (what == 'mukey') { - if (db == "SSURGO") { - q <- sprintf("SELECT mukey, muname - FROM mapunit - WHERE mukey IN ( - SELECT DISTINCT mukey from SDA_Get_Mukey_from_intersection_with_WktWgs84('%s') + + } else { + + if (what == 'mukey') { + if (db == "SSURGO") { + q <- sprintf("SELECT mukey, muname + FROM mapunit + WHERE mukey IN ( + SELECT DISTINCT mukey from SDA_Get_Mukey_from_intersection_with_WktWgs84('%s') + )", wkt) + } else if (db == "STATSGO") { + q <- sprintf("SELECT DISTINCT P.mukey, mapunit.muname + FROM gsmmupolygon AS P + INNER JOIN mapunit ON mapunit.mukey = P.mukey + WHERE mupolygongeo.STIntersects(geometry::STGeomFromText('%s', 4326)) = 1 + AND CLIPAREASYMBOL = 'US'", wkt) + } else { + stop("query type 'mukey' for 'SAPOLYGON' is not supported", call. = FALSE) + } + + } else if (what == 'areasymbol') { + # SSURGO only + q <- sprintf("SELECT areasymbol + FROM sapolygon + WHERE sapolygonkey IN ( + SELECT DISTINCT sapolygonkey from SDA_Get_Sapolygonkey_from_intersection_with_WktWgs84('%s') )", wkt) - } else if (db == "STATSGO") { - q <- sprintf("SELECT DISTINCT P.mukey, mapunit.muname - FROM gsmmupolygon AS P - INNER JOIN mapunit ON mapunit.mukey = P.mukey - WHERE mupolygongeo.STIntersects(geometry::STGeomFromText('%s', 4326) ) = 1 - AND CLIPAREASYMBOL = 'US'", wkt) - } else { - stop("query type 'mukey' for 'SAPOLYGON' is not supported", call. = FALSE) - } - - if (query_string) { - return(q) } - - # single query for all of the features - # note that row-order / number of rows in results may not match geom - res <- suppressMessages(SDA_query(q)) - if (inherits(res, 'try-error')) { - return(res) - } - } - - # SSURGO only - if (what == 'areasymbol') { - q <- sprintf("SELECT areasymbol - FROM sapolygon - WHERE sapolygonkey IN ( - SELECT DISTINCT sapolygonkey from SDA_Get_Sapolygonkey_from_intersection_with_WktWgs84('%s') - )", wkt) - if (query_string) { return(q) } - - # single query for all of the features - # note that row-order / number of rows in results may not match geom - res <- suppressMessages(SDA_query(q)) - if (inherits(res, 'try-error')) { - return(res) - } + res <- suppressMessages(SDA_query(q)) } - res } From 373c58e6b09f2bd00b3f3d4bd0bd7c03d0ceabdc Mon Sep 17 00:00:00 2001 From: Andrew Gene Brown Date: Thu, 18 Apr 2024 14:24:08 -0700 Subject: [PATCH 2/2] .SDA_geometrySelector: refactor to handle non-polygon results --- R/SDA-spatial.R | 21 +++++++++++---------- 1 file changed, 11 insertions(+), 10 deletions(-) diff --git a/R/SDA-spatial.R b/R/SDA-spatial.R index 4f6e5ea7..db74d1a9 100644 --- a/R/SDA-spatial.R +++ b/R/SDA-spatial.R @@ -46,7 +46,7 @@ processSDA_WKT <- function(d, g='geom', crs = 4326, p4s = NULL, as_sf = TRUE) { # STATSGO features require AND CLIPAREASYMBOL = 'US' to avoid state areasymbol copy # select the right query for SSURGO / STATSGO geometry filters submitted to SDA -.SDA_geometrySelector <- function(db, method, geomAcres = TRUE) { +.SDA_geometrySelector <- function(db, what, method, geomAcres = TRUE) { db_table <- switch(db, SSURGO = "mupolygon", STATSGO = "gsmmupolygon", @@ -77,6 +77,14 @@ processSDA_WKT <- function(d, g='geom', crs = 4326, p4s = NULL, as_sf = TRUE) { id_column, geom_sql, id_column, db_table, db_column, clip_sql, id_column, ifelse(geomAcres, area_ac_sql, "") ) + + # handle non-polygon results + if (db == "SSURGO" && what %in% c("mupoint", "muline", "featpoint", "featline")) { + res <- gsub("mupolygon", what, res) + if (what %in% c("featpoint", "featline")) { + res <- gsub("mukey", "featkey", res) + } + } return(res) } @@ -373,23 +381,16 @@ SDA_spatialQuery <- function(geom, if (geomIntersection) { # select the appropriate query - .template <- .SDA_geometrySelector(db = db, method = 'intersection', geomAcres = geomAcres) + .template <- .SDA_geometrySelector(db = db, what = what, method = 'intersection', geomAcres = geomAcres) q <- sprintf(.template, as.character(wkt), as.character(wkt)) } else { # return overlapping # select the appropriate query - .template <- .SDA_geometrySelector(db = db, method = 'overlap', geomAcres = geomAcres) + .template <- .SDA_geometrySelector(db = db, what = what, method = 'overlap', geomAcres = geomAcres) q <- sprintf(.template, as.character(wkt)) } - - if (db == "SSURGO" && what %in% c("mupoint", "muline", "featpoint", "featline")) { - q <- gsub("mupolygon", what, q) - if (what %in% c("featpoint", "featline")) { - q <- gsub("mukey", "featkey", q) - } - } if (query_string) { return(q)