HomeMogDBMogDB StackUqbar
v2.1

Documentation:v2.1

Supported Versions:

Other Versions:

Different Data Is Displayed for the Same Table Queried By Multiple Users

Symptom

Two users log in to the same database human_resource and run the following statement separately to query the areas table, but obtain different results.

select count(*) from areas;

Cause Analysis

  1. Check whether tables with same names are really the same table. In a relational database, a table is identified by three elements: database, schema, and table. In this issue, database is human_resource and table is areas.
  2. Check whether schemas of tables with the same name are consistent. Log in as users omm and user01 separately. It is found that search_path is public and $user, respectively. As omm is the cluster administrator, a schema having the same name as user omm will not be created by default. That is, all tables will be created in public if no schema is specified. However, when a common user, such as user01, is created, the same-name schema (user01) is created by default. That is, all tables are created in user01 if the schema is not specified.
  3. If different users access different data in the same table, check whether objects in the table have different access policies for different users.

Procedure

  • For the query of tables with the same name in different schemas, add the schema reference to the queried table. The format is as follows:

    schema.table
  • If different access policies result in different query results of the same table, you can query the pg_rlspolicy system catalog to determine the specific access rules.

Copyright © 2011-2024 www.enmotech.com All rights reserved.