oracle11gR2中文全部显示为问号怎么解决

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle11gR2中文全部显示为问号怎么解决相关的知识,希望对你有一定的参考价值。

参考技术A 你是在服务器端插入数据的吧,尝试在XP的客户端输入数据试试。 这是因为字符集的问题造成的 你系统字符集是zh_CN.gb2312 环境变量字符集是ZHS16GBK 服务器数据库字符集是 ZHS16GBK 由于你环境变量字符集和你的服务器数据库一样

sql编码为latin1,中文内容全部显示问号,怎么设置

下载的数据库执行文件,编码为latin1,执行后所有中文内容全部显示为问号,这个要怎么设置才能显示中文,或者如何把编码改成gbk或utf-8的格式,执行文件里面有重要数据,如果执行在开头的创建数据库语句修改,里面的数据还是不能正常显示
下面是执行文件的前面一段代码:

CREATE DATABASE `h1e2h453a4i5` DEFAULT CHARACTER SET latin1 COLLATE latin1_swedish_ci;
USE `h1e2h453a4i5`;

下面是某一表格插入的数据

INSERT INTO `pwn_advs_lb` (`id`, `groupid`, `title`, `src`, `src1`, `url`, `xuhao`) VALUES
(39, 1, '????', 'advs/pics/20140102/1388623047.jpg', '', 'http://', 11),
(40, 1, '????', 'advs/pics/20140211/1392082693.jpg', 'advs/pics/20140211/1392082693_s.jpg', 'http://', 15),
(41, 1, '????', 'advs/pics/20140120/1390180936.jpg', 'advs/pics/20140120/1390180936_s.jpg', 'http://', 13),
(51, 1, '????', 'advs/pics/20141117/1416191902.jpg', 'advs/pics/20141117/1416191902_s.jpg', 'http://', 9),
(49, 1, '????', 'advs/pics/20141117/1416191868.jpg', 'advs/pics/20141117/1416191868_s.jpg', 'http://', 7),
(50, 1, '????', 'advs/pics/20140620/1403250073.jpg', 'advs/pics/20140620/1403250073_s.jpg', 'http://', 5),
(55, 1, '????', 'advs/pics/20150121/1421825977.jpg', 'advs/pics/20150121/1421825977_s.jpg', 'http://', 3);

第一种的代码,你可以参考一下:
以下的我找的其中一篇,备份后数据库是空的!
/**
* @param args
*/
public static void
main(String[] args)
/*
* 备份和导入是一个互逆的过程。
*
备份:程序调用mysql的备份命令,读出控制台输入流信息,写入.sql文件;
*
导入:程序调用mysql的导入命令,把从.sql文件中读出的信息写入控制台的输出流
* 注意:此时定向符">"和"<"是不能用的
*/
backup();
load();


/**
*
备份检验一个sql文件是否可以做导入文件用的一个判断方法:把该sql文件分别用记事本和ultra
*
edit打开,如果看到的中文均正常没有乱码,则可以用来做导入的源文件(不管sql文件的编码格式如何,也不管db的编码格式如何)
*/
public static void backup()
try
Runtime rt =
Runtime.getRuntime();

// 调用 mysql 的 cmd:
Process child = rt
.exec("mysqldump -u root --set-charset=utf8 bjse act_obj");//
设置导出编码为utf8。这里必须是utf8

//
把进程执行中的控制台输出信息写入.sql文件,即生成了备份文件。注:如果不对控制台信息进行读出,则会导致进程堵塞无法运行
InputStream in
= child.getInputStream();// 控制台的输出信息作为输入流

InputStreamReader xx =
new InputStreamReader(in, "utf8");// 设置输出流编码为utf8。这里必须是utf8,否则从流中读入的是乱码

String inStr;
StringBuffer sb = new StringBuffer("");
String
outStr;
// 组合控制台输出信息字符串
BufferedReader br = new
BufferedReader(xx);
while ((inStr = br.readLine()) != null)
sb.append(inStr + "\\r\\n");

outStr = sb.toString();

//
要用来做导入用的sql目标文件:
FileOutputStream fout = new FileOutputStream(
"e:/mysql-5.0.27-win32/bin/bjse22.sql");
OutputStreamWriter writer = new
OutputStreamWriter(fout, "utf8");
writer.write(outStr);
//
注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
writer.flush();

//
别忘记关闭输入输出流
in.close();
xx.close();
br.close();
writer.close();
fout.close();

System.out.println("/* Output OK!
*/");

catch (Exception e)
e.printStackTrace();




/**
* 导入
*
*/
public static void load()
try
String fPath = "e:/mysql-5.0.27-win32/bin/bjse22.sql";
Runtime
rt = Runtime.getRuntime();

// 调用 mysql 的 cmd:
Process child =
rt.exec("mysql -u root bjse ");
OutputStream out =
child.getOutputStream();//控制台的输入信息作为输出流
String inStr;
StringBuffer sb
= new StringBuffer("");
String outStr;
BufferedReader br = new
BufferedReader(new InputStreamReader(
new FileInputStream(fPath),
"utf8"));
while ((inStr = br.readLine()) != null)
sb.append(inStr +
"\\r\\n");

outStr = sb.toString();

OutputStreamWriter writer
= new OutputStreamWriter(out, "utf8");
writer.write(outStr);
//
注:这里如果用缓冲方式写入文件的话,会导致中文乱码,用flush()方法则可以避免
参考技术A 下载一个UE文本编辑器,可以支持转码

以上是关于oracle11gR2中文全部显示为问号怎么解决的主要内容,如果未能解决你的问题,请参考以下文章

急求:PHP 中文写入数据库中文是问号,怎么解决

在oracle数据库中插入的冷僻字都会变成问号,这个怎么解决。

Linux启动oracle数据库时,显示很多问号

oracle填坑之PLSQL中文显示为问号

sql编码为latin1,中文内容全部显示问号,怎么设置

PLSQL中table表中的汉字显示问号,装了汉化包之后还是问号,不知道怎么解决