| 261 |
Base table columns permitting URLs without a protocol |
Find non-foreign key base table columns that name refers to the possibility that these are used to register URLs. Find the columns that do not have any simple CHECK constraint that references to a protocol. A simple check constraint covers a single column. In this case registration of URLs without a protocol is most probably not prohibited. |
Problem detection |
INFORMATION_SCHEMA+system catalog base tables |
2025-11-07 10:11 |
MIT License |
View |
| 262 |
Base table columns where TOASTing is possible |
Find all base table columns in case of which the system can use TOAST technique. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 263 |
Base table columns where TOAST-ing strategy has been changed |
Find base table columns in case of which the system can use TOAST technique (due to the data type of the column) and where the toasting strategy has been changed so that it is different than the default strategy determined by the type. Make sure that the new strategy is optimal. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 264 |
Base table columns where TOAST-ing strategy has been changed to plain |
Find base table columns in case of which the system can use TOAST technique (due to the data type of the column) and where the toasting strategy has been changed to plain. It means that potentially, if a value in the column is large enough, it is not possible to save the row. |
Problem detection |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 265 |
Base table columns with a composite type |
Find base table columns with a composite type. Think through as to whether a column with a composite type could be replaced with a separate table. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 266 |
Base table columns with an array type |
Find base table columns with an array type. Think through as to whether a column with an array type could be replaced with a separate table. |
General |
INFORMATION_SCHEMA+system catalog base tables |
2025-11-07 10:11 |
MIT License |
View |
| 267 |
Base table columns with CHAR(n) or VARCHAR(n) type |
Find base table columns with CHAR(n) or VARCHAR(n) type and make sure that n is not too big or too small. Also make sure that you do not use CHAR(n) in case of columns that have to keep variable length strings. "Values of type character are physically padded with spaces to the specified width n, and are stored and displayed that way" (https://www.postgresql.org/docs/current/datatype-character.html) |
General |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 268 |
Base table columns with CITEXT type |
Find base table columns with CITEXT type and make sure that case insensitivity is really needed in case of this column. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 269 |
Base table columns with DECIMAL (p, s) or NUMERIC (p, s) type |
Find base table columns with DECIMAL (p, s) or NUMERIC (p, s) type and make sure that precision p and scale s are not too big or too small. |
General |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 270 |
Base table columns with one of the following types: BIGINT, INTEGER, TEXT, or VARCHAR without max character length |
Each column should have the most appropriate data type. Developers sometimes misuse BIGINT, INTEGER, TEXT or VARCHAR type in places where a type that permits smaller values would be more appropriate and semantically descriptive. |
General |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 271 |
Base table columns with SMALLINT or BOOLEAN type |
Each column should have the most appropriate data type. Developers sometimes forget to use SMALLINT type even if it is logically the best choice. Developers also sometimes forget to use BOOLEAN type and instead invent something. |
General |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 272 |
Base table columns with the same name and type have different field sizes |
Find base table columns that have the same name and type but different field size. |
Problem detection |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 273 |
Base table columns with the type VARCHAR(1) |
The choice of data types should reveal as much as possible about the nature of the data in the column. The type of these columns could be CHAR(1) and they should have a constraint that a value in the column cannot be an empty string. |
Problem detection |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 274 |
Base table columns with UUID type |
Each column should have the most appropriate data type. If one does not want to have in a table the surrogate key that values are generated by using a sequence generator, then one may use instead a column with Universally Unique Identifiers as the key column. |
General |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 275 |
Base table has a national identification number as a key |
Find base table columns that name refers to the possibility that these are used to register national identification numbers (personal codes). Find the columns that constitute a key of a table. This in turn enforces a (restrictive) business rule that all persons of interest come from one country. Make sure that the enforced constraint is valid, i.e., there is indeed such rule in the domain. |
General |
INFORMATION_SCHEMA+system catalog base tables |
2025-11-07 10:11 |
MIT License |
View |
| 276 |
Base tables and foreign tables that do not have any CHECK constraints on non-foreign key columns |
Identify possibly missing CHECK constraints. |
Problem detection |
INFORMATION_SCHEMA+system catalog base tables |
2025-11-07 10:11 |
MIT License |
View |
| 277 |
Base tables and foreign tables that have no CHECK constraints |
What are the base tables and foreign tables without any associated (directly or through domains) check constraints? A NOT NULL constraint is a kind of CHECK constraint. However, this query does not take into account NOT NULL constraints. |
Problem detection |
INFORMATION_SCHEMA only |
2025-11-07 10:11 |
MIT License |
View |
| 278 |
Base tables and materialized views without any index |
Find base tables and materialized views that do not have any index. |
Problem detection |
INFORMATION_SCHEMA+system catalog base tables |
2025-11-07 10:11 |
MIT License |
View |
| 279 |
Base tables created based on a type |
Find base tables that have been created based on a composite type and thnk through as to whether it was really needed. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |
| 280 |
Base tables that do not have a TOAST table |
Find base tables that (due to the types of their columns) do not have an associated TOAST table for storing out-of-line data. |
General |
system catalog base tables only |
2025-11-07 10:11 |
MIT License |
View |