暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

openGauss学习笔记-202 openGauss 数据库运维-常见故障定位案例-不同用户查询同表显示数据不同

原创 shuchaoyang 2024-05-12
207

Table of Contents

openGauss学习笔记-202 openGauss 数据库运维-常见故障定位案例-不同用户查询同表显示数据不同

202.1 不同用户查询同表显示数据不同

202.1.1 问题现象

2个用户登录相同数据库human_resource,同样执行如下查询语句,查询同一张表areas时,查询结果却不一致。

select count(*) from areas;

202.1.2 原因分析

  1. 检查同名表是否是同一张表。在关系型数据库中,确定一张表通常需要3个因素:database、schema、table。从问题现象描述看,database、table已经确定,分别是human_resource、areas。
  2. 检查同名表的schema是否一致。使用omm、user01分别登录发现,search_path依次是public和“$user”。omm作为数据库管理员,默认不会创建omm同名的schema,即不指定schema的情况下所有表都会建在public下。而对于普通用户如user01,则会在创建用户时,默认创建同名的schema,即不指定schema时表都会创建在user01的schema下。
  3. 如果最终判断是同一张表,存在不同用户访问数据不同情况,则需要进一步判断当前该表中对象针对不同的用户是否存在不同的访问策略。

202.1.3 处理办法

  • 对于不同schema下同名表的查询,在查询表时加上schema引用。格式如下。

    schema.table
  • 对于不同访问策略造成对同一表查询结果不同时,可以通过查询pg_rlspolicy系统表来确认具体的访问准则。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

图片

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

文章被以下合辑收录

评论