postgis: add patch from migurski to allow for the passing of a 'bbox' token enabling optimized placement of the bbox/intersects query for complex subqueries- closes #415
This commit is contained in:
parent
e897b832a4
commit
434c303e83
2 changed files with 21 additions and 5 deletions
1
AUTHORS
1
AUTHORS
|
@ -30,6 +30,7 @@ Patches
|
|||
- John Hague
|
||||
- Dennis Luxen
|
||||
- Tom MacWright
|
||||
- Michal Migurski
|
||||
- Andrii Mishkovskyi
|
||||
- Dražen Odobašić
|
||||
- Martijn van Oosterhout
|
||||
|
|
|
@ -281,8 +281,8 @@ featureset_ptr postgis_datasource::features(const query& q) const
|
|||
if (conn && conn->isOK())
|
||||
{
|
||||
PoolGuard<shared_ptr<Connection>,shared_ptr<Pool<Connection,ConnectionCreator> > > guard(conn,pool);
|
||||
|
||||
std::ostringstream s;
|
||||
|
||||
s << "SELECT AsBinary(\""<<geometryColumn_<<"\",'"<< WKB_ENCODING << "') AS geom";
|
||||
std::set<std::string> const& props=q.property_names();
|
||||
std::set<std::string>::const_iterator pos=props.begin();
|
||||
|
@ -292,11 +292,26 @@ featureset_ptr postgis_datasource::features(const query& q) const
|
|||
s <<",\""<<*pos<<"\"";
|
||||
++pos;
|
||||
}
|
||||
s << " from " << table_ << " WHERE \""<<geometryColumn_<<"\" && SetSRID('BOX3D(";
|
||||
s << std::setprecision(16);
|
||||
s << box.minx() << " " << box.miny() << ",";
|
||||
s << box.maxx() << " " << box.maxy() << ")'::box3d,"<<srid_<<")";
|
||||
|
||||
std::ostringstream b;
|
||||
b << "SetSRID('BOX3D(";
|
||||
b << std::setprecision(16);
|
||||
b << box.minx() << " " << box.miny() << ",";
|
||||
b << box.maxx() << " " << box.maxy() << ")'::box3d,"<<srid_<<")";
|
||||
|
||||
std::string find = "!bbox!";
|
||||
if (boost::algorithm::icontains(table_,find)) // if token used place bbox there
|
||||
{
|
||||
std::string table_m = boost::algorithm::to_lower_copy(table_);
|
||||
std::string replace = b.str();
|
||||
boost::algorithm::replace_all(table_m,find,replace);
|
||||
s << " from " << table_m;
|
||||
}
|
||||
else // otherwise append bbox query
|
||||
{
|
||||
s << " from " << table_ << " WHERE \"" << geometryColumn_ << "\" && "<< b.str();
|
||||
}
|
||||
|
||||
if (row_limit_ > 0) {
|
||||
s << " LIMIT " << row_limit_;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue