问题描述
在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进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




