BufferWithTolerance(geography 数据类型)

返回表示所有点值的并集的几何对象,这些点到 geography 实例的距离小于或等于指定值,允许存在指定的公差。

语法

.BufferWithTolerance ( distance, tolerance, relative )

参数

  • distance
    一个指定与 geography 实例的距离的 float 表达式,缓冲区就是环绕该实例而计算出的。

  • tolerance
    指定缓冲区距离的公差的 float 表达式。

    “公差”值指的是理想的缓冲区距离与返回的线性近似段之间的最大偏差。

    例如,点的理想缓冲区距离为圆圈,但是这必须与多边形近似。公差越小,多边形具有的点就越多,这将增加结果的复杂度,但可减少错误。

  • relative
    一个 bit,指定 tolerance 值是相对值还是绝对值。如果为“TRUE”或 1,则公差为相对值并按 tolerance 参数与椭圆体的角度范围 * 赤道半径的乘积进行计算。如果为“FALSE”或 0,则公差为绝对值并且 tolerance 值为理想缓冲区距离与返回的线性近似段之间的绝对最大偏差。

返回类型

SQL Server 返回类型:geography

CLR 返回类型:SqlGeography

注释

负的缓冲区将删除 geography 实例的给定距离的边界内的所有点。

理论缓冲区和计算出的缓冲区之间的误差为 max(tolerance, extents * 1.E-7),其中,tolerance 是 tolerance 参数的值。有关 extents 的详细信息,请参阅geography 数据类型方法引用

示例

下面的示例创建 Point 实例,并使用 BufferWithTolerance() 获取环绕该实例的大致缓冲区。

DECLARE @g geography;
SET @g = geography::STGeomFromText('POINT(-122.34900 47.65100)', 4326);
SELECT @g.BufferWithTolerance(1, .5, 0).ToString();