【YashanDB知识库】Yasldr错误处理

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

问题1. YAS-04113 bracket expected [YASLDR] execute failed**

原因:

导入数据的用户没有dba权限

解决法:

为导入数据的用户赋dba权限:grant dba to username;

问题****2. YAS-00218 string conversion failed

原因:

1、字符集存在不一致(操作系统字符集,源库字符集,目标库字符集)

2、源库导出的数据和YashanDB的表结构不一致

解决法:

1、检查操作系统字符集,源库字符集与目标库的字符集是否一致

--查询操作系统字符集

locale

--查询YashanDB数据库字符集

select * from V$parameter where name='CHARACTER_SET';

--查询Oralce数据库字符集

select * from nls_database_parameters where parameter like '%NLS_CHARACTERSET%';

2、检查源库和YashanDB的表结构是否一致,不一致则修改表结构

问题****3. Fail to connect socket, error 111, error message “Connection refused”

原因:

1、查看数据库是否启动,状态是否正常

2、在主备部署环境下,可能出现归档日志满的情况,当系统硬盘被占满后,会出现数据库异常

解决法:

1、在linux操作系统检查yasdb进程是否存在

ps -ef | grep yasdb

--如果不存在则用以下命令启动数据库

yasboot cluster start -c yashandb;

2、需要修改log的删除模式参数,手动清除归档日志

● 归档日志查看:select * from v$archived_log;

● 更改归档模式清理策略:alter system set ARCH_CLEAN_IGNORE_MODE=both

● 手动清理归档:

--删除所有归档日志

ALTER DATABASE DELETE ARCHIVELOG ALL;

--删除包括2022-01-06 11:30:00之前的归档日志

ALTER DATABASE DELETE ARCHIVELOG until TIME TO_DATE('2022-01-06 11:30:00', 'yyyy-mmdd hh24:mi:ss');

--删除序列号包括71号之前的归档日志

ALTER DATABASE DELETE ARCHIVELOG until SEQUENCE 71;

问题****4. YAS-08019 partition key does not map to any partition

原因:

Oracle导出的分区表数据和yasdb表结构不⼀致

解决案:

需要重新获取Oracle的对应表结构,在yasdb中重新建表

问题****5. YAS-02007 no free extent in tablespace TEST

原因:

1、表空间不足,为表空间添加数据文件

2、也可能是在导入过程中大表存在大量索引分裂,将表空间占满

解决案:

1、为表空间添加数据文件:

alter tablespace test add datafile '.../.../data/db-1-1/dbfiles/TEST6' size 1g autoextend on;

2、在建表完成后,将索引drop掉,待数据都导入完成后,再单独建索引

问题6. LOB件导⼊:****YAS-04892:csv line terminates expect embedded

原因:

数据中存在换行符,yasldr默认不将换行符作为数据包含进包围符内

解决:

在ctl文件中,field前面加入WITHEMBEDDED

问题7. LOB件导YAS-00301:file operation "write file" failed. errno 28. error message"No space left on device"

原因:

表空间剩余空间不够

解决:

为对应的表空间添加数据文件

查看表空间剩余空间大小:

"SELECT id, tablespace_name, status, block_size, total_bytes/1024/1024 as "TOTAL_SIZE(MB)",

CAST((total_bytes-user_bytes)/1024/1024 AS decimal(15,2)) as "USED(MB)",

CAST(user_bytes/1024/1024 AS decimal(15,2)) as "AVAILABLE(MB)",

CAST(user_bytes/total_bytes*100 AS decimal(5,2)) AS FREE_PERCENT FROM dba_tablespaces

LIMIT ${ROWSRETUEN}"

为表空间添加数据文件:

alter tablespace test add datafile '.../.../data/db-1-1/dbfiles/TEST6' size 1g autoextend on;

posted @   YashanDB  阅读(5)  评论(0编辑  收藏  举报
编辑推荐:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
阅读排行:
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· 易语言 —— 开山篇
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
点击右上角即可分享
微信分享提示