写点什么

【YashanDB 知识库】从 PostgreSQL 迁移到 YashanDB 如何进行数据行数比对

作者:YashanDB
  • 2025-02-12
    广东
  • 本文字数:683 字

    阅读完需:约 2 分钟

本文内容来自 YashanDB 官网,原文内容请见https://www.yashandb.com/newsinfo/7863054.html?templateId=1718516


SQL 语句的性能数据可以从视图 v$sql 中获取,针对可能有性能问题的 SQL 语句,可以根据该语句对应的 plan_hash_value 从视图 v$sql_plan 获取到该语句的执行计划。

创建 UDF - REPEAT,后面 SQL 中有用到,格式化输出用 

CREATE OR REPLACE FUNCTION repeat(p_str VARCHAR, p_repeat INT) RETURN VARCHAR
IS v_str VARCHAR(1000);
BEGIN
v_str := '';
IF p_repeat > 0 THEN
FOR i in 1..p_repeat
LOOP
v_str := v_str || p_str;
END LOOP;
END IF;
RETURN v_str;
END;
/
复制代码

根据 plan_hash_value 获取 SQL 文本(以 2609204012 为例) 

SELECT sql_fulltext FROM v$sql WHERE plan_hash_value = 2609204012;
复制代码

SQL 文本输出示例: 

SELECT count(*) AS low_stock FROM (    SELECT s_w_id, s_i_id, s_quantity         FROM bmsql_stock s         WHERE s_w_id = ? AND s_quantity < ? AND s_i_id IN (            SELECT ol_i_id                 FROM bmsql_district                 JOIN bmsql_order_line ON ol_w_id = d_w_id                  AND ol_d_id = d_id                  AND ol_o_id >= d_next_o_id - 20                  AND ol_o_id < d_next_o_id                 WHERE d_w_id = ? AND d_id = ?         )     )
复制代码

获取内存中 SQL 语句的执行计划 

SELECT id, repeat('||', depth) || operation as operation, object_name FROM v$sql_plan WHERE plan_hash_value = 2609204012 AND id IS NOT NULL ORDER BY id;
复制代码

输出示例:


发布于: 刚刚阅读数: 6
用户头像

YashanDB

关注

全自研国产新型大数据管理系统 2022-02-15 加入

还未添加个人简介

评论

发布
暂无评论
【YashanDB知识库】从PostgreSQL迁移到YashanDB如何进行数据行数比对_数据库_YashanDB_InfoQ写作社区