SP/web2py/gluon/packages/dal/pydal/representers/mssql.py

29 lines
948 B
Python
Raw Normal View History

2018-10-25 15:33:07 +00:00
from ..adapters.mssql import MSSQL
from .base import SQLRepresenter, JSONRepresenter
from . import representers, before_type, for_type
@representers.register_for(MSSQL)
class MSSQLRepresenter(SQLRepresenter, JSONRepresenter):
def _make_geoextra(self, field_type, srid):
geotype, params = field_type[:-1].split('(')
if params:
srid = params
return {'srid': srid}
@before_type('geometry')
def geometry_extras(self, field_type):
return self._make_geoextra(field_type, 0)
@for_type('geometry', adapt=False)
def _geometry(self, value, srid):
return "geometry::STGeomFromText('%s',%s)" % (value, srid)
@before_type('geography')
def geography_extras(self, field_type):
return self._make_geoextra(field_type, 4326)
@for_type('geography', adapt=False)
def _geography(self, value, srid):
return "geography::STGeomFromText('%s',%s)" % (srid, value)