2017-12-10 10:35:46 +01:00
|
|
|
|
#include "PgClassContainer.h"
|
|
|
|
|
|
#include "Pgsql_Connection.h"
|
|
|
|
|
|
#include "Pgsql_Col.h"
|
2018-01-08 20:45:52 +01:00
|
|
|
|
#include "PgDatabaseCatalog.h"
|
|
|
|
|
|
#include "PgNamespaceContainer.h"
|
2018-09-02 10:30:30 +00:00
|
|
|
|
#include <iterator>
|
2017-12-10 10:35:46 +01:00
|
|
|
|
|
|
|
|
|
|
std::string PgClassContainer::getLoadQuery() const
|
|
|
|
|
|
{
|
2021-04-01 14:55:20 +02:00
|
|
|
|
std::string q = "SELECT pg_class.oid, relname, relnamespace, reltype, reloftype, "
|
2017-12-10 10:35:46 +01:00
|
|
|
|
" relowner, relam, relfilenode, reltablespace, relpages, "
|
|
|
|
|
|
" reltuples, reltoastrelid, relisshared, relpersistence, "
|
2019-08-10 18:12:26 +02:00
|
|
|
|
" relkind, relispopulated, relfrozenxid, relminmxid, "
|
2021-03-10 19:06:40 +01:00
|
|
|
|
" reloptions, d.description, "
|
2021-04-01 14:55:20 +02:00
|
|
|
|
" pg_total_relation_size(pg_class.oid) AS total_bytes, "
|
|
|
|
|
|
" CASE WHEN relkind='r' THEN pg_indexes_size(pg_class.oid) ELSE 0 END AS index_bytes, "
|
2021-03-10 19:06:40 +01:00
|
|
|
|
" CASE WHEN relkind='r' THEN pg_total_relation_size(reltoastrelid) ELSE 0 END AS toast_bytes, "
|
2021-04-01 14:55:20 +02:00
|
|
|
|
" relacl, pg_get_viewdef(pg_class.oid)";
|
2019-08-10 18:12:26 +02:00
|
|
|
|
|
|
|
|
|
|
if (lessThenVersion(120000))
|
|
|
|
|
|
q += ", relhasoids ";
|
|
|
|
|
|
|
|
|
|
|
|
q +=
|
2021-03-10 19:06:40 +01:00
|
|
|
|
"\nFROM pg_catalog.pg_class \n"
|
2021-03-08 16:59:13 +01:00
|
|
|
|
" LEFT JOIN pg_catalog.pg_description AS d ON (objoid=pg_class.oid AND objsubid=0) \n"
|
2018-12-29 11:19:12 +01:00
|
|
|
|
"WHERE relkind IN ('r', 'i', 'p', 'I', 'v', 'm', 'f')";
|
2019-08-10 18:12:26 +02:00
|
|
|
|
|
|
|
|
|
|
return q;
|
2017-12-10 10:35:46 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
2017-12-12 20:13:53 +01:00
|
|
|
|
PgClass PgClassContainer::loadElem(const Pgsql::Row &row)
|
2017-12-10 10:35:46 +01:00
|
|
|
|
{
|
2017-12-12 20:13:53 +01:00
|
|
|
|
Pgsql::Col col(row);
|
2018-11-25 19:45:06 +01:00
|
|
|
|
Oid class_oid = col.nextValue();
|
|
|
|
|
|
QString name = col.nextValue();
|
|
|
|
|
|
Oid schema_oid = col.nextValue();
|
|
|
|
|
|
|
|
|
|
|
|
PgClass v(m_catalog, class_oid, name, schema_oid);
|
|
|
|
|
|
Oid owner ;
|
|
|
|
|
|
col >> v.type >> v.oftype
|
|
|
|
|
|
>> owner >> v.am >> v.filenode >> v.tablespace >> v.pages_est
|
2017-12-12 20:13:53 +01:00
|
|
|
|
>> v.tuples_est >> v.toastrelid >> v.isshared >> v.persistence
|
2021-03-08 16:59:13 +01:00
|
|
|
|
>> v.kind >> v.ispopulated >> v.frozenxid >> v.minmxid
|
2021-03-10 19:06:40 +01:00
|
|
|
|
>> v.options >> v.description >> v.totalBytes >> v.indexBytes >> v.toastBytes;
|
2019-08-10 18:12:26 +02:00
|
|
|
|
|
|
|
|
|
|
|
2018-12-25 13:17:04 +01:00
|
|
|
|
v.setOwnerOid(owner);
|
2018-12-27 12:05:48 +01:00
|
|
|
|
|
|
|
|
|
|
AclList acl_list;
|
|
|
|
|
|
col >> acl_list;
|
|
|
|
|
|
v.setAcls(std::move(acl_list));
|
|
|
|
|
|
|
2019-10-26 13:13:58 +02:00
|
|
|
|
auto vd = col.nextValue();
|
|
|
|
|
|
if (!vd.null())
|
|
|
|
|
|
v.viewdef = vd.asQString();
|
|
|
|
|
|
|
2019-08-10 18:12:26 +02:00
|
|
|
|
if (lessThenVersion(120000))
|
|
|
|
|
|
col >> v.hasoids;
|
|
|
|
|
|
|
2017-12-12 20:13:53 +01:00
|
|
|
|
return v;
|
2017-12-10 10:35:46 +01:00
|
|
|
|
}
|