ST_SetBandIsNoData — バンドのisnodataフラグをTRUEにします。
raster ST_SetBandIsNoData(
raster rast, integer band=1)
;
バンドのisnodataフラグをTRUEにします。バンドを指定しない場合には、1番と仮定します。isnodataフラグが汚れている場合にのみ呼ぶべきものです。ST_BandIsNoDataの、最後の引数にTRUEを設定した場合の結果と指定しない場合の結果とで異なっている時です。
Availability: 2.0.0
-- ラスタカラムを一つ持つダミーテーブルを生成します create table dummy_rast (rid integer, rast raster); -- 2バンドでバンドごとに1ピクセルを持つラスタを追加します -- 一つ目のバンドにはnodatavalueとピクセル値をともに3とし、 -- 二つ目のバンドにはnodatavalue=13とピクセル値=4とします。 insert into dummy_rast values(1, ( '01' -- little endian - リトルエンディアン (uint8 ndr) || '0000' -- version - 版 (uint16 0) || '0200' -- nBands - バンド数 (uint16 0) || '17263529ED684A3F' -- scaleX - X方向セルサイズ (float64 0.000805965234044584) || 'F9253529ED684ABF' -- scaleY - Y方向セルサイズ (float64 -0.00080596523404458) || '1C9F33CE69E352C0' -- ipX - 左上隅X値 (float64 -75.5533328537098) || '718F0E9A27A44840' -- ipY - 左上隅Y値 (float64 49.2824585505576) || 'ED50EB853EC32B3F' -- skewX - スキューX (float64 0.000211812383858707) || '7550EB853EC32B3F' -- skewY - スキューY (float64 0.000211812383858704) || 'E6100000' -- SRID (int32 4326) || '0100' -- width - 横セル数 (uint16 1) || '0100' -- height - 縦セル数 (uint16 1) || '4' -- hasnodatavalueをTRUEにし、isnodata値を (TRUEにするべきところ)FALSEにする || '2' -- 1番バンドのタイプ (4BUI) || '03' -- NODATA値==3 || '03' -- 0列0行ピクセルの値==3 (NODATA値と同じ) || '0' -- hasnodatavalueをFALSEにする。 || '5' -- 2番バンドのタイプ (16BSI) || '0D00' -- NODATA値==13 || '0400' -- 0列0行ピクセルの値==4 )::raster ); select st_bandisnodata(rast, 1) from dummy_rast where rid = 1; -- FALSEを期待 select st_bandisnodata(rast, 1, TRUE) from dummy_rast where rid = 1; -- TRUEを期待 -- isnodataフラグが汚れているのでTRUEに設定します update dummy_rast set rast = st_setbandisnodata(rast, 1) where rid = 1; select st_bandisnodata(rast, 1) from dummy_rast where rid = 1; -- TRUEを期待