比较 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;