SP/web2py/gluon/packages/dal/pydal/representers/mssql.py
Saturneic 064f602b1a Add.
2018-10-25 23:33:13 +08:00

29 lines
948 B
Python

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)