文档首页 > > 开发指南> 优化查询性能> SQL执行troubleshooting> 不同用户查询同表显示数据不同

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

分享
更新时间: 2019/06/24 GMT+08:00

问题现象

2个用户登录相同数据库human_resource,分别执行的查询语句如下:select count(*) from areas,查询同一张表areas时,查询结果却不一致。

原因分析

请先判断同名的表是否确实是同一张表。在关系型数据库中,确定一张表通常需要3个因素:database,schema,table。从问题现象描述看,database,table已经确定,分别是human_resource、areas。接着,需要检查schema。使用dbadmin,user01分别登录发现,search_path依次是public和"$user"。dbadmin作为集群管理员,默认不会创建dbadmin同名的schema,即不指定schema的情况下所有表都会建在public下。而对于普通用户如user01,则会在创建用户时,默认创建同名的schema,即不指定schema时表都会创建在user01的schema下。最终确定该案例发生时,确实因为2个用户之间交错对表进行操作,导致了同名不同表的情况。

处理方法

在操作表时加上schema引用,格式:schema.table。

分享:

    相关文档

    相关产品

文档是否有解决您的问题?

提交成功!

非常感谢您的反馈,我们会继续努力做到更好!

反馈提交失败,请稍后再试!

*必选

请至少选择或填写一项反馈信息

字符长度不能超过200

提交反馈 取消

如您有其它疑问,您也可以通过华为云社区问答频道来与我们联系探讨

跳转到云社区