doc/fuse_db.sql
author Tero Marttila <terom@fixme.fi>
Fri, 17 Oct 2008 18:53:05 +0300
changeset 33 c71f3053c714
parent 32 90e14e0df133
child 35 4f10421681d2
permissions -rw-r--r--
working symlink
CREATE TABLE inodes (
    ino serial4 primary key, 
    type char(3) NOT NULL, 
    mode int2 NOT NULL, 
    data oid
);

CREATE TABLE file_tree (
    "offset" serial4 primary key, 
    name varchar(256), 
    parent int4 references inodes(ino), 
    inode int4 references inodes(ino) NOT NULL
);

INSERT INTO inodes VALUES 
    (1, 'DIR', 365, NULL),
    (2, 'REG', 292, lo_create(0));

INSERT INTO file_tree (name, parent, inode) VALUES 
    (NULL,  NULL,   1   ),
    ('foo', 1,      2   );

CREATE FUNCTION lo_size (oid) RETURNS int4 LANGUAGE SQL STABLE RETURNS NULL ON NULL INPUT AS 'select lo_lseek(lo_open($1, 262144), 0, 2);';
CREATE FUNCTION lo_pread (IN fd int4, IN len int4, IN "off" int4) RETURNS bytea LANGUAGE SQL STRICT AS 'select lo_lseek($1, $3, 0); select loread($1, $2);';
CREATE FUNCTION lo_pwrite (IN fd int4, IN buf bytea, IN "off" int4) RETURNS int4 LANGUAGE SQL STRICT AS 'select lo_lseek($1, $3, 0); select lowrite($1, $2);';
CREATE FUNCTION lo_otruncate (IN oid, IN len int4) RETURNS oid LANGUAGE SQL STRICT AS 'select lo_truncate(lo_open($1, 393216), $2); select $1;';

ALTER TABLE inodes ADD COLUMN link varchar(512);

CREATE SEQUENCE ino_seq START 64;
ALTER TABLE inodes ALTER COLUMN ino SET DEFAULT nextval('ino_seq'::regclass);

ALTER TABLE file_tree ADD COLUMN ino int4;
UPDATE file_tree SET ino = inode;
ALTER TABLE file_tree DROP COLUMN inode;

CREATE FUNCTION dbfs_size (type char, oid, link varchar) RETURNS int4 LANGUAGE SQL STABLE AS $$
    SELECT CASE $1 
        WHEN 'LNK' THEN char_length($3) 
        WHEN 'REG' THEN lo_size($2) 
        ELSE 0 
    END;
$$;