oracle数据导出spool方式,中文出现乱码是什么原因?

oracle数据导出spool方式,中文出现乱码是什么原因?,第1张

一般来说,oracle数据导出spool方式,中文出现乱码,这情况是因为数据库服务器和客户端字符集不匹配,执行sqlplus的机器就是客户端,服务器和客户端也可能是一台机器,执行sqlplus之前要先设置客户端的字符集,在linux上:export NLS_LANG=.......

在windows上set NLS_LANG查询数据库字符集:select property_value from database_properties where property_name like 'NLS_CHAR%'

1、比如查询结果是:ZHS16GBK

那你在sqlplus之前要设置:export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

然后再登录sqlplus用spool生成数据

检查下你导出时候的环境变量,导入时的环境变量

2、比如导出时NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

导入时NLS_LANG没有设置,或者设置为其他字符集,则导入的库内汉字就有可能变成乱码。

解决方法,连接数据库的时候设置正确字符集即可。

一般是web服务器页面的编码与数据库不一致导致

比如做一些设置<%@Language=JScript @CodePage=936%>

1,<%@codepage="65001"%>

2,<http-equiv="Content-Type" content="text/htmlcharset=UTF-8">

3,Session.CodePage = 65001

4,文件存成 UTF-8

大部分数据库都支持以unicode编码方式,

所以解决与数据库之间的乱码问题比较明智的方式是直接使用unicode编码与数据库交互。

很多数据库驱动自动支持unicode,如Microsoft的SQLServer驱动。

其他大部分数据库驱动,可以在驱动的url参数中指定,如mm的mysql驱动:

jdbc:mysql://localhost/WEBCLDB?useUnicode=true&characterEncoding=GBK。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9994376.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存