sql - postgres : find all integer columns with its current max value in it

标签 sql postgresql information-schema

如何从 Postgres 实例中所有数据库的所有表中查找所有具有当前最大值的整数类型主键列?

我想从所有表中找到所有接近溢出其最大值 2147483647 的 int 类型主键列。

最佳答案

CREATE OR REPLACE FUNCTION intpkmax() RETURNS
   TABLE(schema_name name, table_name name, column_name name, max_value integer)
   LANGUAGE plpgsql STABLE AS
$$BEGIN
   /* loop through tables with a simgle integer column as primary key */
   FOR schema_name, table_name, column_name IN
      SELECT sch.nspname, tab.relname, col.attname
         FROM pg_class tab
            JOIN pg_constraint con ON con.conrelid = tab.oid
            JOIN pg_attribute col ON col.attrelid = tab.oid
            JOIN pg_namespace sch ON sch.oid = tab.relnamespace
         WHERE con.contype = 'p'
            AND array_length(con.conkey, 1) = 1
            AND col.atttypid = 'integer'::regtype
            AND NOT col.attisdropped
   LOOP
      /* get the maximum value of the primary key column */
      EXECUTE 'SELECT max(' || quote_ident(column_name) ||
              ') FROM ' || quote_ident(schema_name) ||
              '.' || quote_ident(table_name) || ''
         INTO max_value;
      /* return the next result */
      RETURN NEXT;
   END LOOP;
END;$$;

然后你可以得到一个列表

SELECT * FROM intpkmax();

关于sql - postgres : find all integer columns with its current max value in it,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42712604/

相关文章:

用于自动递增 varchar(不是主键)的 MySQL 触发器

sql - 是否可以在链接服务器上创建临时表?

sql - 同一张表上的postgres递归查询

permissions - 如何授予其他人在 BigQuery 中读取我的 INFORMATION_SCHEMA.SCHEMATA 的权限?

sql - 通过连接多个表来更新表中的列

sql - 带有两个函数语句的 PostgreSQL 触发器

ruby-on-rails - 从 RoR 查询 postgreSQL 比从提示查询慢?

Python、Postgres 和具有空值的整数?

MySQL:根据列数选择多个表

mysql - 如何查找所有包含columnS和column的表