-
子查询表达式 - 数据仓库服务 GaussDB(DWS)
IN::= 右边是一个圆括弧括起来的子查询,它必须只返回一个字段。左边表达式对子查询结果的每一行进行一次计算和比较。如果找到任何相等的子查询行,则IN结果为true。如果没有找到任何相等行,则结果为false(包括子查询没有返回任何行的情况)。 表达式或子查询行里的NULL遵照SQL处理布
-
查询资源统计信息列表 - 数据仓库服务 GaussDB(DWS)
查询资源统计信息列表 功能介绍 该接口用于查询当前可用资源数量,其中包括“可用集群和总集群(个)”、“可用节点和总节点(个)”、“总容量(GB)”。 调用方法 请参见如何调用API。 URI GET /v1.0/{project_id}/statistics 表1 路径参数 参数
-
模式可见性查询函数 - 数据仓库服务 GaussDB(DWS)
模式可见性查询函数 每个函数对数据库对象执行可见性检查。对于函数和操作符,如果在前面的搜索路径中没有相同的对象名称和参数的数据类型,则此对象是可见的。对于操作符类,则要同时考虑名字和相关索引的访问方法。 所有这些函数都需要使用OID来标识要需要检查的对象。如果用户想通过名字测试对
-
执行动态查询语句 - 数据仓库服务 GaussDB(DWS)
执行动态查询语句 介绍执行动态查询语句。GaussDB(DWS)提供两种方式:使用EXECUTE IMMEDIATE、OPEN FOR实现动态查询。前者通过动态执行SELECT语句,后者结合了游标的使用。当需要将查询的结果保存在一个数据集用于提取时,可使用OPEN FOR实现动态查询。
-
不同用户查询同表显示数据不同 - 数据仓库服务 GaussDB(DWS)
不同用户查询同表显示数据不同 问题现象 2个用户登录相同数据库human_resource,分别执行的查询语句如下:select count(*) from areas,查询同一张表areas时,查询结果却不一致。 原因分析 请先判断同名的表是否确实是同一张表。在关系型数据库中,
-
全并行的数据查询处理 - 数据仓库服务 GaussDB(DWS)
全并行的数据查询处理 功能描述 全并行的分布式查询处理是DWS中最核心的技术,它可以最大限度的降低查询时节点之间的数据流动,以提升查询效率。 DWS为达成高性能数据分析目标,实现了一套高性能的分布式执行引擎,执行引擎以SQL引擎生成的执行计划为输入,将元组按执行计划的要求进行加工并将结果返回给客户端。
-
查询数据库对象权限 - 数据仓库服务 GaussDB(DWS)
查询数据库对象权限 功能介绍 该接口用于查询数据库对象权限。 调用方法 请参见如何调用API。 URI GET /v1/{project_id}/clusters/{cluster_id}/db-manager/authority 表1 路径参数 参数 是否必选 参数类型 描述 project_id
-
其他优化器选项 - 数据仓库服务 GaussDB(DWS)
参数说明:标识在短查询加速打开时,查询是否需要加速。 参数类型:USERSET 取值范围:整型,-1~1 -1:短查询由快车道管控,长查询由慢车道管控。 0:查询不加速,短查询和长查询均由慢车道管控。 1:查询加速,短查询和长查询均由快车道管控。 默认值:-1 show_unshippable_warning
-
GaussDB(DWS)列存表的常用信息查询 - 数据仓库服务 GaussDB(DWS)
GaussDB(DWS)列存表的常用信息查询 使用列存表时,一些常用信息查询SQL示例: 先创建列存分区表my_table,并向表中插入数据。 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 CREATE TABLE
-
GaussDB(DWS)查询时索引失效场景解析 - 数据仓库服务 GaussDB(DWS)
GaussDB(DWS)查询时索引失效场景解析 对表建立索引可提高数据库查询性能,但有时会出现建立了索引,但查询计划中却发现索引没有被使用的情况。针对这种情况,本文将列举几种常见的场景和优化方法。 场景一:返回结果集很大 以行存表的Seq Scan和Index Scan为例: Seq
-
指定子查询不提升的hint - 数据仓库服务 GaussDB(DWS)
指定子查询不提升的hint 功能描述 优化器在对查询进行逻辑优化时通常会将可以提升的子查询提升到上层以避免嵌套执行,但对于某些场景,嵌套执行不会导致性能下降过多,而提升之后扩大了查询路径的搜索范围,可能导致性能变差。对于此类情况,可以使用no merge hint指定子查询不提升
-
案例:改写SQL消除子查询(案例1) - 数据仓库服务 GaussDB(DWS)
customer_address_001 a; 此SQL性能较差,查看发现执行计划中存在SubPlan,引用SubPlan结果的算子可能需要反复的调用获取这个SubPlan的值,即SubPlan以下的结果要重复执行很多次。具体如下: 优化说明 此优化的核心就是消除子查询。那么从SQL语义出发,可以等价改写SQL为:
-
查询某个资源管理计划详细信息 - 数据仓库服务 GaussDB(DWS)
查询某个资源管理计划详细信息 功能介绍 该接口用于查询某个资源管理计划详细信息。 调用方法 请参见如何调用API。 URI GET /v2/{project_id}/clusters/{cluster_id}/workload/plans/{plan_id} 表1 路径参数 参数
-
查询资源管理计划阶段详细信息 - 数据仓库服务 GaussDB(DWS)
查询资源管理计划阶段详细信息 功能介绍 该接口用于查询资源管理计划阶段详细信息。 调用方法 请参见如何调用API。 URI GET /v2/{project_id}/clusters/{cluster_id}/workload/plans/{plan_id}/stages/{stage_id}
-
不同用户查询同表显示数据不同 - 数据仓库服务 GaussDB(DWS)
不同用户查询同表显示数据不同 问题现象 2个用户登录相同数据库human_resource,分别执行的查询语句如下:SELECT count(*) FROM areas,查询同一张表areas时,查询结果却不一致。 原因分析 请先判断同名的表是否确实是同一张表。在关系型数据库中,
-
查询专属分布式存储池列表 - 数据仓库服务 GaussDB(DWS)
查询专属分布式存储池列表 功能介绍 该接口用于获取专属分布式存储池列表,只包括用户开通的SSD专属资源池信息。 调用方法 请参见如何调用API。 URI 1 GET /v1.0/{project_id}/dss-pools 表1 路径参数 参数 是否必选 参数类型 描述 project_id
-
执行动态非查询语句 - 数据仓库服务 GaussDB(DWS)
执行动态非查询语句 语法 语法请参见图1。 图1 noselect::= using_clause子句的语法参见图2。 图2 using_clause-2 对以上语法格式的解释如下: USING IN bind_argument用于指定存放传递给动态SQL值的变量,在dynami
-
查询和索引统计收集器 - 数据仓库服务 GaussDB(DWS)
查询和索引统计收集器 查询和索引统计收集器负责收集数据库系统运行中的统计数据,如在一个表和索引上进行了多少次插入与更新操作、磁盘块的数量和元组的数量、每个表上最近一次执行清理和分析操作的时间等。可以通过查询系统视图pg_stats和pg_statistic查看统计数据。下面的参数设置服务器范围内的统计收集特性。
-
如何将联结查询的null结果替换成0? - 数据仓库服务 GaussDB(DWS)
如何将联结查询的null结果替换成0? 在执行outer join(left join、right join、full join)联结查询时,outer join在匹配失败的情况下结果集会补空,产生大量NULL值, 可以在联结查询时将这部分null值替换为0。 可使用coales
-
执行动态非查询语句 - 数据仓库服务 GaussDB(DWS)
执行动态非查询语句 语法 语法请参见图1。 图1 noselect::= using_clause子句的语法参见图2。 图2 using_clause-2 对以上语法格式的解释如下: USING IN bind_argument用于指定存放传递给动态SQL值的变量,在dynami