supporto per SqlGeography
è stato aggiunto nella prossima release, ancora una volta tramite il pacchettoDapper.EntityFramework
. Non ho ancora creato/implementato, dato che ho due idee sul fatto che sia l'assemblaggio più appropriato in cui vivere ... ma non voglio prendere dipendenza da Microsoft.SqlServer.Types
nella libreria principale. Potrebbe esserci un modo per farlo senza quello, però.
Aggiornamento: questo è ora spostata di un livello alla libreria di base, in modo da non dovrebbe essere necessario alcun riferimento EF o Dapper.EntityFramework
; dovrebbe funzionare solo; questo è stato spinto come Dapper 1.32.
Esempio:
public void SqlGeography_SO25538154()
{
Dapper.SqlMapper.ResetTypeHandlers(); // to show it doesn't depend on any
connection.Execute("create table #SqlGeo (id int, geo geography)");
var obj = new HazSqlGeo
{
Id = 1,
Geo = SqlGeography.STLineFromText(
new SqlChars(new SqlString(
"LINESTRING(-122.360 47.656, -122.343 47.656)")), 4326)
};
connection.Execute("insert #SqlGeo(id, geo) values (@Id, @Geo)", obj);
var row = connection.Query<HazSqlGeo>(
"select * from #SqlGeo where id=1").SingleOrDefault();
row.IsNotNull();
row.Id.IsEqualTo(1);
row.Geo.IsNotNull();
}
class HazSqlGeo
{
public int Id { get; set; }
public SqlGeography Geo { get; set; }
}
fonte
2014-08-28 07:09:04
Che tipo (s) stai usando attualmente per mappare questi? Stai usando 'SqlGeography' direttamente? o...? –
correlati; http://stackoverflow.com/questions/6690565/using-dapper-with-sql-spatial-types-as-a-parameter/25544690#25544690 e http://stackoverflow.com/questions/12090549/mapping-sqlgeography- with-dapper? lq = 1 –