The physical space, in bytes, occupied by the database SistemaComercial can be calculated using the function pg_database_size():
SELECT pg_database_size( 'SistemaComercial' );
To get the free space of a deteminated partition and/or drive, you can write a stored Procedure using the language PL/Python, let’s see:
CREATE FUNCTION calcular_espaco_livre( path TEXT )
RETURNS BIGINT AS
$BODY$
    import os
    info = os.statvfs( path )
    return info.f_bsize * info.f_bavail
$BODY$
LANGUAGE plpythonu;
So you can write another stored Procedure in PL/PgSQL to solve your problem:
CREATE FUNCTION obter_espaco_ocupado( dbnome TEXT )
RETURNS REAL AS
$BODY$
DECLARE
    diretorio TEXT;
    livre BIGINT;
    ocupado BIGINT;
BEGIN
    -- Recupera o diretorio onde a database está instalada
    SELECT setting FROM pg_settings WHERE name = 'data_directory' INTO diretorio;
    -- Calcula o espaco livre desse diretorio
    SELECT calcular_espaco_livre( diretorio ) INTO livre;
    -- Calcula o espaco ocupado pela database
    SELECT pg_database_size( dbnome ) INTO ocupado;
    -- Calcula a porcentagem ocupada
    RETURN (100.0 / livre) * ocupado;
END;
$BODY$
LANGUAGE plpgsql;
Soon:
SELECT obter_espaco_ocupado( 'SistemaComercial' );
							
							
						 
This SQL brings the value you need?
– novic
Using this select in the database, it returns me the space occupied in kilobytes. I needed it to be in percent... Does it have any way of calculating? Another detail: The function is something I built, but I don’t know how to do with EF Core, because you probably need to run sql.
– Master JR
Percentage over which value? yes there is the possibility to make a method to return the pg_database_size!
– novic
The occupied percentage relative to the total size of the database... It should return the occupied percentage with data... Ex: Occupied space 10%.
– Master JR
In vdd, I think it will be necessary to make some calculation where the total size of the database will be discounted with the space used..
– Master JR
The used space ? seat size already has !!! correct, but, space than that ????
– novic
Space used (which has already been used for data recording).
– Master JR
Let’s go continue this discussion in chat.
– novic