mirror of
https://github.com/postgres/postgres.git
synced 2025-08-24 09:27:52 +03:00
Add API for 64-bit large object access. Now users can access up to
4TB large objects (standard 8KB BLCKSZ case). For this purpose new libpq API lo_lseek64, lo_tell64 and lo_truncate64 are added. Also corresponding new backend functions lo_lseek64, lo_tell64 and lo_truncate64 are added. inv_api.c is changed to handle 64-bit offsets. Patch contributed by Nozomi Anzai (backend side) and Yugo Nagata (frontend side, docs, regression tests and example program). Reviewed by Kohei Kaigai. Committed by Tatsuo Ishii with minor editings.
This commit is contained in:
@@ -125,6 +125,29 @@ SELECT lo_tell(fd) FROM lotest_stash_values;
|
||||
SELECT lo_close(fd) FROM lotest_stash_values;
|
||||
END;
|
||||
|
||||
-- Test 64-bit largelbject functions.
|
||||
BEGIN;
|
||||
UPDATE lotest_stash_values SET fd = lo_open(loid, CAST(x'20000' | x'40000' AS integer));
|
||||
|
||||
SELECT lo_lseek64(fd, 4294967296, 0) FROM lotest_stash_values;
|
||||
SELECT lowrite(fd, 'offset:4GB') FROM lotest_stash_values;
|
||||
SELECT lo_tell64(fd) FROM lotest_stash_values;
|
||||
|
||||
SELECT lo_lseek64(fd, -10, 1) FROM lotest_stash_values;
|
||||
SELECT lo_tell64(fd) FROM lotest_stash_values;
|
||||
SELECT loread(fd, 10) FROM lotest_stash_values;
|
||||
|
||||
SELECT lo_truncate64(fd, 5000000000) FROM lotest_stash_values;
|
||||
SELECT lo_lseek64(fd, 0, 2) FROM lotest_stash_values;
|
||||
SELECT lo_tell64(fd) FROM lotest_stash_values;
|
||||
|
||||
SELECT lo_truncate64(fd, 3000000000) FROM lotest_stash_values;
|
||||
SELECT lo_lseek64(fd, 0, 2) FROM lotest_stash_values;
|
||||
SELECT lo_tell64(fd) FROM lotest_stash_values;
|
||||
|
||||
SELECT lo_close(fd) FROM lotest_stash_values;
|
||||
END;
|
||||
|
||||
-- lo_unlink(lobjId oid) returns integer
|
||||
-- return value appears to always be 1
|
||||
SELECT lo_unlink(loid) from lotest_stash_values;
|
||||
|
Reference in New Issue
Block a user