sql编码为latin1,中文内容全部显示问号,怎么设置 10
下载的数据库执行文件,编码为latin1,执行后所有中文内容全部显示为问号,这个要怎么设置才能显示中文,或者如何把编码改成gbk或utf-8的格式,执行文件里面有重要数据...
下载的数据库执行文件,编码为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); 展开
下面是执行文件的前面一段代码:
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); 展开
2个回答
推荐于2017-12-15
展开全部
第一种的代码,你可以参考一下:
以下的我找的其中一篇,备份后数据库是空的!
/**
* @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()方法则可以避免
以下的我找的其中一篇,备份后数据库是空的!
/**
* @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()方法则可以避免
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询