疑难Tips:解决 SQL*Plus 中工具插入中文数据到Oracle数据库报错及乱码问题

eb88136e2c88947077e35ea895abd580.gif

[ 知识是人生的灯塔,只有不断学习,才能照亮前行的道路 ]

原文地址:疑难Tips:解决 SQL*Plus 中工具插入中文数据到Oracle数据库报错及乱码问题在SQL*Plus执行插入语句中含有中文时,出现ORA-01756错误和乱码。这两个问题源于客户端与服务器端字符集不一致。插入中文时,转码可能导致字符串终止符错误,从而引发插入错误;编码不匹配则导致乱码,而统一字符集可同时解决这两个问题。https://mp.weixin.qq.com/s/dAU4k8BNKRW8_2bKycmIPA

解决在 sqlplus 命令行中插入 Oracle 中文数据报错及乱码问题 

错误信息:在 sqlplus 命令行中执行下述插入语句,报 ORA-01756: quoted string not properly terminated ,以及乱码问题。

SQL> insert into test(id,name) values (6,'Oracle关系型数据库');
ERROR:
ORA-01756: quoted string not properly terminated

问题原因:可将上述两个问题合并到一起解决,问题1解决了,问题2自然也就解决了。前者是由于在 sqlplus 命令行中插入中文数据时,由于使用的 XSHELL 或者 MobaXterm 终端(作者环境)的客户端字符集不一致,插入中文时会经行转码,导致某些字符串可能转成中文符号导致sql出现错误,后者则sqlplus客户端使用的编码和服务器端编码不一致导致乱码。

问题解决

  • 1.查看数据库服务端字符集,客户端编码以及当前会话的字符集,NLS_LANG 的组成规则为 NLS_LANGUAGE_NLS_TERRITORY.NLS_CHARACTERSET 。

-- 1.查看数据库服务端字符集
SELECT userenv('language') FROM dual;  -- AMERICAN_AMERICA.ZHS16GBK
SELECT * FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER IN ('NLS_LANGUAGE', 'NLS_TERRITORY', 'NLS_CHARACTERSET');
-- NLS_CHARACTERSET ZHS16GBK
-- NLS_TERRITORY AMERICA
-- NLS_LANGUAGE AMERICAN-- 2.查看sqlplus客户端编码
SELECT * FROM V$NLS_PARAMETERS WHERE PARAMETER IN ('NLS_LANGUAGE', 'NLS_TERRITORY', 'NLS_CHARACTERSET');
-- NLS_LANGUAGE         AMERICAN
-- NLS_TERRITORY        AMERICA
-- NLS_CHARACTERSET     ZHS16GBK-- 3.查看当前会话的字符集
SELECT * FROM nls_session_parameters  WHERE parameter in ( 'NLS_LANGUAGE','NLS_TERRITORY','NLS_CHARACTERSET');
-- NLS_LANGUAGE  AMERICAN
-- NLS_TERRITORY  AMERICA
  • 2.修改 MobaXterm 终端工具字符集,并将其设置为 gbk , 重新打开终端在MobaXterm终端上执行 export LANG=zh_CN.GBK , 需根据数据库实际编码调整。

 

cf493a4f599fddf40458c0c63a216f99.png

weiyigeek.top-修改 MobaXterm 终端工具字符集图
  • 3.使用 MobaXterm 连接的是远程服务器,若远程服务器存在字符编码问题,我们还可以在远程服务器上修改系统字符集。

declare -x LANG="zh_CN.gbk"
declare -x LC_ALL="zh_CN.gbk"
  • 4.最后远程服务器设置 sqlplus 客户端字符集,使其与服务端保持一致。

    • Linux 环境:执行 export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK 命令,或者将此命令放于 Oracle 用户的Shell启动 .bash_profile 中,并执行 source ~/.bash_profile 使之生效。

    • Windows 环境:计算机->属性->高级系统设置->环境变量->新建 NLS_LANG 变量 ,变量值设置为 AMERICAN_AMERICA.ZHS16GBK  或者 执行 set nls_lang=american_america.ZHS16GBK 命令。

验证配置

set headingoff
set line 300 pagesize 999
truncatetabletest;  -- 清空表数据
insertintotest(id,name) values (1, '关系型数据库');
insertintotest(id,name) values (2, 'MySQL');
insertintotest(id,name) values (3, 'Oracle');
insertintotest(id,name) values (4, '"达梦数据库"');
insertintotest(id,name) values (5, '中文测试');
updatetestsetname = '"DM达梦数据库"'whereid=5;-- 若然不行,则使用最终大法绑定变量来插入中文数据
VARIABLE v_id NUMBER;
VARIABLE v_name VARCHAR2(100);
EXEC :v_id := 6;   -- PL/SQL 过程已成功完成。
EXEC :v_name := '中文测试';  -- PL/SQL procedure successfully completed.
INSERTINTOtest(id,name) VALUES (:v_id,:v_name);
1 row created.-- 测试结果:
SQL> select * fromtest;1 关系型数据库2 MySQL3 Oracle5 "DM达梦数据库"4 "达梦数据库"6 中文测试
6 rows selected.
SQL> commit;
Commit complete.

aa4409e5458e0e9b7b570558b534413c.png

weiyigeek.top-解决sqlplus插入中文及乱码问题图

知识扩展:使用 Navicat Premium 连接 Oracle 数据库,在 Navicat Premium 中插入中文数据在 sqlplus 命令行中查询是乱码,解决办法如下:编辑 Oracle 连接配置,设置客户端字符集 为 ZHS16GBK 编码默认为 65001 (UTF-8),保存后重新连接即可, 插入两条中文数据测试。

41ca39b3912f0e3b496423df0bbf426c.png

weiyigeek.top-解决navicat插入中文乱码问题图

“苦海无边,学海无涯”

关注作者学习更多实用DBA实用技巧!

若文章写得不错,不要吝惜手中转发,点赞、在看,若有疑问的小伙伴,可在评论区留言你想法哟💬!

温馨提示:作者最近10年的工作学习笔记(涉及网络、安全、运维、开发),需要学习实践笔记的看友,可添加作者账号[WeiyiGeeker],当前价格¥199,除了获得从业笔记的同时还可进行问题答疑以及每月远程技术支持,希望大家多多支持,收获定大于付出!

3b868703fb5173456e0ad5d7de4ab50e.png


如果此篇文章对你有帮助,请你将它转发给更多的人! 

原文地址:

疑难Tips:解决 SQL*Plus 中工具插入中文数据到Oracle数据库报错及乱码问题在SQL*Plus执行插入语句中含有中文时,出现ORA-01756错误和乱码。这两个问题源于客户端与服务器端字符集不一致。插入中文时,转码可能导致字符串终止符错误,从而引发插入错误;编码不匹配则导致乱码,而统一字符集可同时解决这两个问题。https://mp.weixin.qq.com/s/dAU4k8BNKRW8_2bKycmIPA

54543a68f339467f910c018af6163098.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/4624.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Mac 上如何安装Mysql? 如何配置 Mysql?以及如何开启并使用MySQL

前言: 有许多开发的小伙伴,使用的是mac,那么在mac上如何安装,配置Mysql,以及使用Mysql了,今天来一个系统的教程。 安装Mysql 使用mysql前,我们需要先下载mysql,并按照以下几个步骤…

iOS中的设计模式(三)- 工厂方法

引言 几乎在每个用面向对象语言开发的应用程序中,都能见到工厂方法模式的身影。它是 抽象工厂模式 的核心组成部分。通过重载抽象工厂父类中定义的工厂方法,各种具体工厂能够创建属于自己的对象。 在工厂方法模式中,生产者 本身并不一定是抽…

VSCode最新离线插件拓展下载方式

之前在vscode商店有以下类似的download按钮,但是2025年更新之后这个按钮就不提供了,所以需要使用新的方式下载 ps:给自己的网站推广下~~(国内直连GPT/Claude) 新的下载方式1 首先打开vscode商店官网:vscode插件下载…

2024人工智能AI+制造业应用落地研究报告汇总PDF洞察(附原数据表)

原文链接: https://tecdat.cn/?p39068 本报告合集洞察深入剖析当前技术应用的现状,关键技术 创新方向,以及行业应用的具体情况,通过制造业具体场景的典型 案例揭示人工智能如何助力制造业研发设计、生产制造、运营管理 和产品服…

【2024 年度总结】从小白慢慢成长

【2024 年度总结】从小白慢慢成长 1. 加入 CSDN 的契机2. 学习过程2.1 万事开头难2.2 下定决心开始学习2.3 融入技术圈2.4 完成万粉的目标 3. 经验分享3.1 工具的选择3.2 如何提升文章质量3.3 学会善用 AI 工具 4. 保持初心,继续前行 1. 加入 CSDN 的契机 首次接触…

Unity Shader学习日记 part5 CG基础

在了解完Shader的基本结构之后,我们再来看看编写着色器的语言。 Shader编写语言有CG,HLSL两种,我们主要学习CG的写法。 数据类型 CG的基础变量类型 uint a12;//无符号32位整形 int b12;//32位整形float f1.2f;//32位浮点型 half h1.2h;//…

AI Agent:深度解析与未来展望

一、AI Agent的前世:从概念到萌芽 (一)早期探索 AI Agent的概念可以追溯到20世纪50年代,早期的AI研究主要集中在简单的规则系统上,这些系统的行为是确定性的,输出由输入决定。随着时间的推移,…

【24】Word:小郑-准考证❗

目录 题目 准考证.docx 邮件合并-指定考生生成准考证 Word.docx 表格内容居中表格整体相较于页面居中 考试时一定要做一问保存一问❗ 题目 准考证.docx 插入→表格→将文本转换成表格→✔制表符→确定选中第一列→单击右键→在第一列的右侧插入列→布局→合并单元格&#…

计算机网络 (46)简单网络管理协议SNMP

前言 简单网络管理协议(SNMP,Simple Network Management Protocol)是一种用于在计算机网络中管理网络节点的标准协议。 一、概述 SNMP是基于TCP/IP五层协议中的应用层协议,它使网络管理员能够管理网络效能,发现并解决网…

机器人“大脑+小脑”范式:算力魔方赋能智能自主导航

在机器人技术的发展中,“大脑小脑”的架构模式逐渐成为推动机器人智能化的关键。其中,“大脑”作为机器人的核心决策单元,承担着复杂任务规划、环境感知和决策制定的重要角色,而“小脑”则专注于运动控制和实时调整。这种分工明确…

Linux 使用 GDB 进行调试的常用命令与技巧

GDB 调试的常用命令与技巧 1. GDB 常用命令1.1 安装 GDB1.2 启动 GDB1.3 设置程序的参数1.4 设置断点1.5 启动程序并运行至断点1.6 执行一步1.7 打印变量值1.8 查看函数调用栈 2. GDB 调试 Core 文件2.1 生成 Core 文件2.2 使用 GDB 调试 Core 文件 3. GDB 调试正在运行的程序3…

光谱相机如何还原色彩

多光谱通道采集 光谱相机设有多个不同波段的光谱通道,可精确记录每个波长的光强信息。如 8 到 16 个甚至更多的光谱通道,每个通道负责特定波长范围的光信息记录。这使得相机能分辨出不同光谱组合产生的相同颜色感知,而传统相机的传感器通常只…

AUTOSAR从入门到精通-线控底盘技术

目录 几个高频面试题目 为何高阶智能驾驶需要线控底盘 线控底盘与传统底盘有何区别? 算法原理 线控技术发展背景 国外研究现状 国内研究现状 什么是线控底盘? 组成结构是什么? 线控底盘的发展: 线控底盘名词解释: 汽车线控系统关键技术 线控底盘的组成 电子…

跨境电商使用云手机用来做什么呢?

随着跨境电商的发展,越来越多的卖家开始尝试使用云手机来协助他们的业务,这是因为云手机具有许多优势。那么,具体来说,跨境电商使用云手机可以做哪些事情呢? (一)实现多账号登录和管理 跨境电商…

springboot项目属性配置方式

基于上篇博客 springboot项目部署到本地,本博客主要讲springboot项目属性配置方式,这篇文章将在后几天持续维护、更新。

Java 多态/向下转型/instanceof

1. 多态 1.1 概述 多态:事务的不同形态,如 动物,其有多种形态:猫,狗之类的; 1.2 使用方法 虚拟方法(父类被重写的方法在多态中叫做虚拟方法)调用: 父类引用指向子类…

【Maven】resources-plugin

在使用maven的项目中,它默认加载的是resources目录下的资源文件,像properties、xml 这类资源文件,但有时候可能会定义在java 源码目录下,这时候运行项目就会报找不到资源文件的错误 来到classpath 下,发现没有这个xsd…

我的创作纪念日——我与CSDN一起走过的365天

目录 一、机缘:旅程的开始 二、收获:沿路的花朵 三、日常:不断前行中 四、成就:一点小确幸 五、憧憬:梦中的重点 一、机缘:旅程的开始 最开始开始写博客是在今年一二月份的时候,也就是上一…

Restormer: Efficient Transformer for High-Resolution Image Restoration解读

论文地址:Restormer: Efficient Transformer for High-Resolution Image Restoration。 摘要 由于卷积神经网络(CNN)在从大规模数据中学习可推广的图像先验方面表现出色,这些模型已被广泛应用于图像复原及相关任务。近年来&…

Nginx location 和 proxy_pass 配置详解

概述 Nginx 配置中 location 和 proxy_pass 指令的不同组合方式及其对请求转发路径的影响。 配置效果 1. location 和 proxy_pass 都带斜杠 / location /api/ {proxy_pass http://127.0.0.1:8080/; }访问地址:www.hw.com/api/upload转发地址:http://…