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

解决KingbaseES数据库sys_dump逻辑备份表失败的问题

数据猿 2021-12-08
1266

问题描述

KingbaseES数据库中逻辑备份时,使用-n schema_name -t table_name方式备份某个模式下的一张表时,备份失败,报错“no matching tables were found”。

 

 

原因分析

当-t被使用时,-n和-N开关不会有效果,因为被-t选择的表将被转储而无视那些开关,并且非表对象将不会被转储。

上图中,tab1在dump_table模式中,-t参数并未指定模式名,且public模式下无同名表,故报错无法找到匹配的表。


解决办法

通过 –t schema_name.table_name的方式进行备份。

如:

./sys_dump -Usystem -dtest -p15500 -t dump_table.tab1 -F p -f test.sql

 

查看test.sql:

--

-- Kingbase database dump

--

-- Dumped from database version 12.1

-- Dumped by sys_dump version 12.1

SET statement_timeout = 0;

SET lock_timeout = 0;

SET idle_in_transaction_session_timeout = 0;

SET client_encoding = 'UTF8';

SET standard_conforming_strings = on;

SELECT pg_catalog.set_config('search_path', 'public', false);

SET check_function_bodies = false;

SET xmloption = content;

SET client_min_messages = warning;

SET row_security = off;

SET default_tablespace = '';

SET default_table_access_method = heap;

--

-- Name: tab1; Type: TABLE; Schema: dump_table; Owner: system

--

CREATE TABLE dump_table.tab1 (

    a integer

);

ALTER TABLE dump_table.tab1 OWNER TO system;

--

-- Data for Name: tab1; Type: TABLE DATA; Schema: dump_table; Owner: system

--

COPY dump_table.tab1 (a) FROM stdin;

1

\.

--

-- Kingbase database dump complete

--

表被成功备份。


 

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

评论