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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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文本编辑器,可以支持转码

使用Outlook 2003收到的邮件,中文内容全显示为问号怎么解决?

今天收到香港发过来邮件,里面的中文内容全显示为问号怎么解决?之前和香港那边收发都没有问题?

参考技术A 这是乱码
需要重新编码

鼠标右键点邮件,选择查看源文件
就能看到主要的文本内容

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

从数据库中取出的中文为啥是问号

mysql不支持中文,把所有编码格式改成gbk,重新登陆后又变回了latin1,这是为啥

PHP插入MYSQL数据库中文变成乱码 问号

使用Outlook 2003收到的邮件,中文内容全显示为问号怎么解决?

php输入数据库,显示为问号,而不是应该的中文?

使用Outlook 2003收到的邮件,中文内容全显示为问号怎么解决?