名称

ST_BandIsNoData — 如果波段仅填充有无数据值,则返回 true。

语法

boolean ST_BandIsNoData(raster rast, integer band, boolean forceChecking=true);

boolean ST_BandIsNoData(raster rast, boolean forceChecking=true);

说明

如果波段仅填充有无数据值,则返回 true。如果没有指定,则假设为波段 1。如果最后一个参数为 TRUE,则逐像素检查整个波段。否则,该函数仅返回波段的 isnodata 标志的值。如果未指定,此参数的默认值为 FALSE。

可用性:2.0.0

[Note]

如果标志为脏标志(即,使用 TRUE 作为最后一个参数和不使用它时结果不同),则应使用 ST_SetBandIsNodata() 或 ST_SetBandNodataValue()(最后一个参数为 TRUE)将该标志设置为 true 来更新栅格。请参阅 ST_SetBandIsNoData

示例

-- Create dummy table with one raster column
create table dummy_rast (rid integer, rast raster);

-- Add raster with two bands, one pixel/band. In the first band, nodatavalue = pixel value = 3.
-- In the second band, nodatavalue = 13, pixel value = 4
insert into dummy_rast values(1,
(
'01' -- little endian (uint8 ndr)
||
'0000' -- version (uint16 0)
||
'0200' -- nBands (uint16 0)
||
'17263529ED684A3F' -- scaleX (float64 0.000805965234044584)
||
'F9253529ED684ABF' -- scaleY (float64 -0.00080596523404458)
||
'1C9F33CE69E352C0' -- ipX (float64 -75.5533328537098)
||
'718F0E9A27A44840' -- ipY (float64 49.2824585505576)
||
'ED50EB853EC32B3F' -- skewX (float64 0.000211812383858707)
||
'7550EB853EC32B3F' -- skewY (float64 0.000211812383858704)
||
'E6100000' -- SRID (int32 4326)
||
'0100' -- width (uint16 1)
||
'0100' -- height (uint16 1)
||
'6' -- hasnodatavalue and isnodata value set to true.
||
'2' -- first band type (4BUI)
||
'03' -- novalue==3
||
'03' -- pixel(0,0)==3 (same that nodata)
||
'0' -- hasnodatavalue set to false
||
'5' -- second band type (16BSI)
||
'0D00' -- novalue==13
||
'0400' -- pixel(0,0)==4
)::raster
);

select st_bandisnodata(rast, 1) from dummy_rast where rid = 1; -- Expected true
select st_bandisnodata(rast, 2) from dummy_rast where rid = 1; -- Expected false
            

另请参阅

ST_BandNoDataValueST_NumBandsST_SetBandNoDataValueST_SetBandIsNoData