比较 bytea 和 plpgsql 中的 bytea
comparing bytea to bytea in plpgsql
我正在编写一个函数,它将从大对象中读取数据并将其与作为 arg 提供的数据进行比较。 (我想确保我写得正确,这是一个 post 写完整性检查)
我已经弄明白如何分块读取大对象了
fd := lo_open(looid,x'40000'::int);
loop
buff := loread(fd, 1000);
len := octet_length(buff);
raise NOTICE 'buff %', len;
if len = 0 then
exit;
end if;
end loop;
return 0;
但我坚持将每个块与我的输入 bytea(比如 indata)的等效切片进行比较的看似简单的操作。我什至不知道从哪里开始,广泛的 ggoling 没有任何线索
使用substring(string [from int] [for int])
.
循环可能如下所示:
offst := 1;
loop
buff := loread(fd, 1000);
len := octet_length(buff);
raise NOTICE 'buff %', len;
if buff <> substring(indata from offst for 1000) then
return false;
end if;
if len = 0 then
return true;
end if;
offst := offst + len;
end loop;
我正在编写一个函数,它将从大对象中读取数据并将其与作为 arg 提供的数据进行比较。 (我想确保我写得正确,这是一个 post 写完整性检查)
我已经弄明白如何分块读取大对象了
fd := lo_open(looid,x'40000'::int);
loop
buff := loread(fd, 1000);
len := octet_length(buff);
raise NOTICE 'buff %', len;
if len = 0 then
exit;
end if;
end loop;
return 0;
但我坚持将每个块与我的输入 bytea(比如 indata)的等效切片进行比较的看似简单的操作。我什至不知道从哪里开始,广泛的 ggoling 没有任何线索
使用substring(string [from int] [for int])
.
循环可能如下所示:
offst := 1;
loop
buff := loread(fd, 1000);
len := octet_length(buff);
raise NOTICE 'buff %', len;
if buff <> substring(indata from offst for 1000) then
return false;
end if;
if len = 0 then
return true;
end if;
offst := offst + len;
end loop;