2009/2/4 David Wall <d.w...@computer.org> > > First, LOs seem to allow an OID column to be added to any number of tables, > but is it true that the actual large object data is stored in a single table > (pg_largeobject?).
yes. http://www.postgresql.org/docs/8.3/static/lo-intro.html > If so, wouldn't this become a bottleneck if LOs were used frequently? > Even vacuuming and vacuumlo must create a lot of pressure on that one table > if LOs are used extensively. And can you backup a table with an OID column > and get only those LOs referenced in the dump? > > Does the JDBC library support LO streaming? Can I receive data, compress, > encrypt and stream into the database as well as do the opposite when reading > it back? http://jdbc.postgresql.org/documentation/83/index.html see Large Objects and "Storing Binary Data" transparent encryption is not implemented in the driver but of course it is possible. > If I have an "unlimited" number of name-value pairs that I'd like to get > easy access to for flexible reports, could I store these in two arrays (one > for name, the other for value) in a table so that if I had 10 name-value > pairs or 200 name-value pairs, I could store these into a single row using > arrays so I could retrieve all name-value pairs in a single SELECT from the > db? yes you could, but what for? what's wrong with many rows? create table kvstore(key text primary key,value text); what stops you from using single SELECT to get all these kv pairs? > How are these arrays stored -- does it use an underlying type like LO or > BYTEA? > > How big can an LO get? Is it 2GB? no, much larger. I guess it's limited by max table size. see http://www.postgresql.org/docs/faqs.FAQ.html#item4.4 > > How many LO fields can I have in a database? as many as the max number of different OIDs .. minus the number of system objects so I think 2^31 large objects is possible without problem. > It seems that the LO may even be implemented as an OID with one or more > BYTEA storage structure in the pg_largeobject table (loid,pageno,data). Is > that true? that's how it is actually implemented - you probably know it already :) > > > How big is a "page"? Maybe an LO is more efficient than a BYTEA if it's > bigger than one page? default and recommended page size is 8 kB. > > > How big can a BYTEA get? Is it 1GB? Yes. > > At what size does it make more sense to store in LO instead of a BYTEA > (because of all the escaping and such)? > How many BYTEA fields can I have in a database? no limit (other than limits mentioned in the FAQ) > Are the BYTEA fields stored in the same table as the rest of the data? yes - and the TOAST tables if it's larger than 1/3 of a page or so. search for TOAST details if you're interested. > I believe this is yes, so a backup of that table will include the binary > data, too, correct? > yes > > How big can an ARRAY get? Is it 1GB? yes > > How many ARRAY fields can I have in a table or database? Are there > limits? same as bytea or any other type > > Are the ARRAY fields stored in the same table as the rest of the data? I guess ARRAYs are serialized and stored according to same rules as any other data (TOAST mechanism). > > > Sorry for all the questions, but I'm trying to research it but the info is > not always clear (and perhaps some of the stuff I find is not even true). most of your questions are answered in the documentation and FAQ. > > > I am wondering if when my encrypted XML data is small, should I choose to > store it in a table using BYTEA so that each "record" in my application > (which uses the encrypted XML name-value storage) is not forced to be in a > single pg_largeobject table, and use LO when my data reaches a threshold > size? Thoughts? I'd avoid LO unless you really need streaming (block-wise) access. cheers, -- Filip Rembiałkowski JID,mailto:filip.rembialkow...@gmail.com http://filip.rembialkowski.net/