Code前端首页关于Code前端联系我们

解决Oracle乱码问题,先问chatGPT

terry 2年前 (2023-09-26) 阅读数 86 #后端开发

现象

Oracle数据库字符集是ZHS16GBK
,添加查询和查询♷乱码:显示乱码Oracle乱码问题处理解决方式,先问chatGPT

解决方案

Ak CHATGPT 首先找到答案:Oracle乱码问题处理解决方式,先问chatGPT

输出:

  • ONE是将罕见字符的数据类型从VARCHAR2更改为NVARCHAR2,并使用utl_raw.cast_to_nvarchar2
    插入和查询数据。这个函数比较小。
  • 另一种是更改数据库字符集为支持更多汉字的字符集,例如AL32UTF8
    或ZHS32GB18030。这需要删除数据库并重建它,这是一大步。 事实上,测试表明问题仍然存在。

例如生僻词:㼆yíng,㱔suǒ,䶮yǎn

 1-- 解决Oracle存储生僻字、偏僻字
 2-- 只能保证业务系统能正常读取生僻字
 3
 4DROP TABLE TEST;
 5CREATE TABLE TEST(id int,n1 varchar2(255), n2 nvarchar2(255));
 6insert into TEST values(0,'张学?䄲友','张学?䄲友');
 7insert into TEST values(1,n'张学?䄲友',n'张学?䄲友');
 8insert into TEST VALUES(0,'㱔','㱔');
 9insert into TEST VALUES(1,'㱔',N'㱔');
10insert into TEST VALUES(1,'㛃',N'㛃');
11insert into TEST VALUES(0,'䶮','䶮');
12insert into TEST VALUES(0,'㼆','㼆');
13
14
15
16-- 中文转unicode参考:https://www.w3cschool.cn/tools/index?name=unicode_chinese
17insert into TEST select 1,utl_raw.cast_to_varchar2('3c54'),utl_raw.cast_to_nvarchar2('3c54')from dual;
18insert into TEST select 1,utl_raw.cast_to_varchar2('36c3'),utl_raw.cast_to_nvarchar2('36c3')from dual;
19commit;
20
21-- ID为1且n2列为正确的插入方法
22SELECT n1,n2 FROM TEST;
23
24
25
26-- 补充
27-- 测试 sql
28select n'䄲' from dual; -- 显示正常
29select '䄲' from dual; -- 显示乱码

解法:

1-- 第一步: 将需要存储生僻字的字段类型修改为 nvarchar2 (注意:不是 varchar2)
2alter table TEST modify N1 nvarchar2(255);
3
4-- 第二步: 手工通过数据库图形化工具 将生僻字转换后 插入该字段(单引号前面加上 n)
5update TEST set sqrmc = n'张学?䄲友' where sblsh = '44180022B0000NJ';
6commit;
7
8-- 第三步: 进入业务系统页面查看 正常显示为 《 张学?䄲友 》

实验

 1[oracle@lhrora11204 ~]$ dbca -silent -createDatabase -templateName General_Purpose.dbc -responseFile NO_VALUE 
 2> -gdbname gbk  -sid gbk 
 3> -sysPassword lhr -systemPassword lhr 
 4> -datafileDestination '/u01/app/oracle/oradata' 
 5> -recoveryAreaDestination '/u01/app/oracle/flash_recovery_area' 
 6> -redoLogFileSize 50 
 7> -storageType FS 
 8> -characterset ZHS16GBK -nationalCharacterSet AL16UTF16 
 9> -sampleSchema true 
10> -totalMemory 512 
11> -databaseType OLTP  
12> -emConfiguration NONE
13/bin/cat: /proc/sys/net/core/wmem_default: No such file or directory
14/bin/cat: /proc/sys/net/core/wmem_default: No such file or directory
15/bin/cat: /proc/sys/net/core/wmem_default: No such file or directory
16Copying database files
171% complete
183% complete
1911% complete
2018% complete
2126% complete
2237% complete
23Creating and starting Oracle instance
2440% complete
2545% complete
2650% complete
2755% complete
2856% complete
2957% complete
3060% complete
3162% complete
32Completing Database Creation
3366% complete
3470% complete
3573% complete
3685% complete
3796% complete
38100% complete
39Look at the log file "/u01/app/oracle/cfgtoollogs/dbca/gbk/gbk.log" for further details.
40[oracle@lhrora11204 ~]$ export ORACLE_SID=gbk
41[oracle@lhrora11204 ~]$ sas
42
43SQL*Plus: Release 11.2.0.4.0 Production on Tue Mar 7 17:34:32 2023
44
45Copyright (c) 1982, 2013, Oracle.  All rights reserved.
46
47
48Connected to:
49Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
50With the Partitioning, OLAP, Data Mining and Real Application Testing options
51
52SYS@gbk> select userenv('language') from dual;
53
54USERENV('LANGUAGE')
55----------------------------------------------------
56AMERICAN_AMERICA.ZHS16GBK
57
58SYS@gbk> 

varchar2 和 nvarchar2 的区别 Oracle varchar2 和 nvarchar2 如下 点:
  • var char2 是一个可变长度字符类型,最多可存储 4000 个字节的数据,而 nvarchar2 是可变长度国家字符类型,最多可存储 2000 个字符。
  • varchar2 的长度单位可以是字节或字符,具体取决于类型参数,而 nvarchar2 的长度单位只能是字符。
  • varchar2在存储汉字时受数据库字符编码的影响。例如,GBK编码中1个汉字占用2个字节,UTF-8编码中1个汉字占用3个字节。 nvarchar2存储汉字时,不受数据库字符集编码的影响。一个汉字总是占用两个字节。
  • varchar2 和 nvarchar2 在插入和检索数据时可能需要使用不同的函数来转换数据类型。 ?通过在字符串前添加“N”前缀或使用 utl_raw.cast_to_nvarchar2('unicode code')
    来添加或修改。

2。大多数罕见字符都在UTF8字符集中,这意味着它们可以正确存储在Oracle数据库的AL32UTF8字符集中。

3。如果数据库是UTF8格式,建议可以正常工作。如果字符仍然混乱,您可以编辑 NLS_LANG
参数。

1export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

该参数在 Windows 上也需要编辑, Oracle乱码问题处理解决方式,先问chatGPT

如果 plsql Developer 显示问题:在 plsql Developer 中的工具--“首选项---选项”下选择 Unicode 用法来显示它。 Oracle乱码问题处理解决方式,先问chatGPT

参考

https://www.modb.pro/db/125984

版权声明

本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

热门