我正在使用 Spatial.NHibernate 将一些几何形状保存到 Sql Server 2008 中的地理列。这是我的映射:
public class AreaMapping : ClassMap<Area>
{
public AreaMapping()
{
Id(c => c.Id).GeneratedBy.HiLo(100.ToString());
Map(c => c.Name).Not.Nullable();
Map(x => x.Boundary)
.CustomTypeIs<MsSql2008GeographyType>()
.Not.Nullable()
.CustomSqlTypeIs("GEOGRAPHY");
}
}
映射似乎是有效的。这是课程:
public class Area
{
public virtual Guid Id { get; set; }
public virtual Polygon Boundary { get; set; }
public virtual string Name { get; set; }
}
但是,当我去保存这样的区域时:
Area area = new Area{ Boundary = new Polygon(new LinearRing(new ICoordinate[]{
new Coordinate(-1.911524, 55.136334),
new Coordinate(-1.912679, 55.136293),
new Coordinate(-1.912689, 55.136178),
new Coordinate(-1.911507, 55.136194),
new Coordinate(-1.911524, 55.136334)}))
Session.Save(area);
我收到以下错误:
指定的输入不代表有效的地理实例。
类型:System.ArgumentException 来源:Microsoft.SqlServer.Types TargetSite:Microsoft.SqlServer.Types.SqlGeography ConstructGeographyFromUserInput(Microsoft.SqlServer.Types.GeoData, Int32) ...等。
我知道地理类型的有效多边形必须逆时针绘制,并且必须关闭,并且不能与自身重叠。我很确定我正在满足所有这些限制(尽管如果我错了请纠正我)所以我在这里有点难过。要么我的多边形有问题,要么 NHibernate 没有正确保存它 - 欢迎任何帮助!
编辑 好吧,我现在很困惑。
为了简化事情,我将多边形更改为:
Area area = new Area{ Boundary = new Polygon(new LinearRing(new ICoordinate[]{
new Coordinate(10,15),
new Coordinate(10,5),
new Coordinate(20,5),
new Coordinate(20,15),
new Coordinate(10,15)}))
我也一样
指定的输入不代表有效的地理实例。
请注意,多边形是逆时针绘制的(因为它应该根据各种来源)。但是,如果我将坐标更改为顺时针:
Area area = new Area{ Boundary = new Polygon(new LinearRing(new ICoordinate[]{
new Coordinate(10,15),
new Coordinate(20,15),
new Coordinate(20,5),
new Coordinate(10,5),
new Coordinate(10,15)}))
好像没问题。那么顺时针有效还是什么?