数据库读出乱码解决
一、分析常见数据库问题
修改MYSQL数据库,数据表,字段的编码(解决JSP乱码)
要解决JSP乱码,首先就要了解JSP乱码的原因
1.架设服务器安装MYSQL时的会让你选择一种编码,如果这种编码与你的网页不一致,可能就会造成JSP页面乱码
2.在PHPMYADMIN或mysql-front等系统创建数据库时会让你选择一种编码,如果这种编码与你的网页不一致,也有可能造成JSP页面乱码
3.创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成JSP页面乱码
4.创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成JSP 页面乱码
5.用户提交JSP页面的编码与显示数据的JSP页面编码不一致,就肯定会造成JSP页面乱码.
如用户输入资料的JSP页面是big5码,显示用户输入的JSP页面却是gb2312,这种100%会造成JSP页面乱码
6.字符集不正确
要注意:
1.平时你在某些网站看到的文字可能有几种编码,如你看到一个繁体字,它有可能是big5编码,也有可能是utf-8编码的,更有可能是gb码的,没错,也就是说有简体编码的繁体字,也有繁体编码的简体字,一定要了解这一点.
如果你是做一个简体编码的网页,编码定为GB2312,如果有香港和台湾地区的访客提交繁体的信息,就可能会造成乱码,解决方法就是(1)将网站编码设为utf-8,这样可以兼容世界上所有字符,(2)如果网站已经运作了好久,已有很多旧数据,不能再更改简体中文的设定,那么建议将页面的编码设为GBK,
GBK与GB2312的区别就在于:GBK能比GB2312显示更多的字符,要显示简体码的繁体字,就只能用GBK
7.JSP连接MYSQL数据库语句指定的编码不正确
8.JSP页面没有指定数据提交的编码,就会造成乱码:
所以,JSP乱码的原因无非就是以上几种,知道原因之后,要解决JSP乱码的方法也容易多了
我们一一来表达:
1.如果安装mysql的编码已不能更改,很多朋友是购买虚拟主机建立网站,无权更改MYSQL的安装编码,这一关我们可以跳过,因为只要后面的步聚正确,一样能解决乱码问题
2.修改数据库编码,如果是数据库编码不正确:可以在phpmyadmin执行如下命令:ALTER DATABASE`test`DEFAULT CHARACTER SET utf8COLLATE utf8_bin
以上命令就是将test数据库的编码设为utf8
3.修改表的编码:ALTER TABLE`category`DEFAULT CHARACTER SET utf8COLLATE utf8_bin
以上命令就是将一个表category的编码改为utf8
4.修改字段的编码:
ALTER TABLE`test`CHANGE`dd``dd`VARCHAR(45)CHARACTER SET utf8COLLATE
天然绿松石鉴别图utf8_bin NOT NULL
以上命令就是将test表中dd的字段编码改为utf8
5.如果是这种情况容易解决,只需检查下页面,修改源文件的charset即可
,//这个正确就无问题了
6.这种情况也是修改页面charset即可,
7.在JSP连接数据库的语句中,
private String url="jdbc:mysql://localhost/"+DB_NAME+"
user="+LOGIN_NAME+"&password="+LOGIN_PASSWORD+"&characterEncoding=GBK";//相键要看characterEncoding
8.这种乱码的情况,只需在页面开头加上request.setCharacterEncoding("GBK");指定提交的即可
注意:按照以上方法修改以后只能保证你新插入的数据不会乱码,举个例:如果你用户已提交的数据是BIG5,你却想通过以上方法改为可以在GB2312的网页正确显示是不可能的,这种文字内码的变换只能通过另写程序来解决,请WEB745其它相关文章
总结:先要判断JSP乱码是插入数据库之后乱码,还是JSP页面刚提交过来就乱码了,如果JSP 刚接收上一页面的数据显示就乱码了,肯定是字符集不对,可者没有加
request.setCharacterEncoding("GBK");
jsp中文全称如果是数据库的原因就参考上面的2,3,4种方法
可能是编码问题
这样连接一下数据库看看
jdbc:mysql://localhost:3306/xxxx useUnicode=true&characterEncoding=UTF-8
看看能否有效果
二、乱码案例
使用MYSQL数据库,用JSP去连接结果发现出了很多问题,主要集中在乱码显示上面,实际
开发中,想必这类问题是见怪不怪了。
正在装载数据……
搜索了互联网上面很多的帖子,反复推敲,有几点心得写下来,以
后碰到类似的问题,也防止自己忘记要重新来过:
blog.csdn/fly29/archive/2004/07/31/57084.aspx
刚开始学JSP,就碰到中文乱码问题,在CSDN上看了不少帖子,有点小的启示,还好问题解决了。
今天是碰到关于页面传值,进行显示中文出现乱码的问题。
------------------------------
name:
Email:sql2008配置管理器
<%@page language="java"%>
<%@page contentType="text/html;charset=gb2312"%>
---------------------------------
服务器之间的信息传输用的是ISO8859_1
而浏览器显示用的是gb2312
用getParameter()的时候,是获得服务器之间传输的信息
所以要指定编码,这就是getBytes("ISO8859_1")
然后用于显示,所以要转换成gb2312
所以String s=new String(getParameter("xxxx").getBytes("ISO8859_1"),"gb2312");
----------------------------------
学到了不少东东,在网上看到还有很多关于中文显示乱码问题,涉及到数据库操作,嗨,只因自己
太菜,还没接触。不过也要先贴过来,以后能用的到的吧。
------------------------------------
利用JDBC连接MYSQL数据库时,连接字符串改成:
String url="jdbc:mysql://server/tzw?useUnicode=true&characterEncoding=GB2312";
这种方法,
-------------------------------------
中文乱码显示原因可能还涉及到OS,JDBC VERSION,
学习中...
上面这篇文章是我搜索了很多文章中选出来的,他说得很明白了,乱码问题主要原理就像上面所说的,页
面传值问题。
下面的总结得也很好:
一)JSP中文乱码问题解决方法小结
blog.csdn/chm_y/archive/2004/07/03/33277.aspx
在使用JSP的过程中,最使人头疼的一个问题就是中文乱码问题,以下是我在软件开发中遇到的乱码问题
电脑c语言用什么软件以及解决方法。
1、JSP页面乱码
这种乱码的原因是应为没有在页面里指定使用的字符集编码,解决方法:只要在页面开始地方用下面
代码指定字符集编码即可:
<%@page contentType="text/html;charset=gb2312"language="java"import="java.sql.*"
errorPage="err.jsp"%>
2、数据库乱码
这种乱码会使你插入数据库的中文变成乱码,或者读出显示时也是乱码,解决方法如下:
在数据库连接字符串中加入编码字符集
String
Url="jdbc:mysql://localhost/digitgulf?user=root&password=root&useUnicode=true&characterEncoding=GB23
12";
并在页面中使用如下代码:
response.setContentType("text/html;charset=gb2312");
request.setCharacterEncoding("gb2312");
3、中文作为参数传递乱码
当我们把一段中文字符作为参数传递个另一页面时,也会出现乱码情况,解决方法如下:
在参数传递时对参数编码,比如
RearshRes.jsp?keywords="+de(keywords)
然后在接收参数页面使用如下语句接收
keywords=new Parameter("keywords").getBytes("8859_1"));
以上为现阶段遇到的乱码问题,乱码的核心问题还是字符集编码问题,只要掌握了这一点,一般的乱
码问题都可以解决。
综合:
JSP连接MYSQL出现乱码,有两个原因,一个是JSP页面设置的原因,还有一个是MYSQL数据库字符设置的原
因,我们先解决后者。
首先进入MYSQL,运行命令:show create table test(test是你具体的数据库里面的一个表的名字),然
后会出现类似下面的信息:
CREATE TABLE`t_course`(
`id`int(11)NOT NULL,
`course_code`varchar(10)NOT NULL,
`course_name`varchar(50)default NULL,
`college`varchar(10)default NULL,
`course_time`varchar(10)default NULL,
`start_end`varchar(10)default NULL,
`course_tech`varchar(10)default NULL,
`course_credit`varchar(10)default NULL,
`course_site`varchar(30)default NULL,
`course_note`text
)ENGINE=InnoDB DEFAULT
CHARSET=gb2312
这段信息重要的部分在于后面的:“DEFAULT CHARSET=gb2312”,如果不是这个信息,而是“DEFAULT CHARSET=latin1”,则直接在数据库执行插入包含中文的数据(insert into test values('中国'))将会
出现乱码,通过JSP执行插入中文数据到MYSQL也是一样乱码,所以我改成我上面所示的CHARSET才行(DEFAULT CHARSET=gb2312)。
方法有几种:
1、建表前先用语句:set names gbk;
如:
网页设计代码结构图set names gbk;
DROP TABLE IF EXISTS grade;
CREATE TABLE grade(
Name varchar(30)NOT NULL default'',
note char(3)NOT NULL default'',
ID tinyint(4)NOT NULL default'0',
PRIMARY KEY(ID)
)TYPE=MyISAM;
--
--Dumping data for table'grade'
--
INSERT INTO grade VALUES('初一','c1',2);
INSERT INTO grade VALUES('初二','c2',3);
INSERT INTO grade VALUES('初三','c3',4);
INSERT INTO grade VALUES('初中','c',1);
INSERT INTO grade VALUES('高一','g1',6);
INSERT INTO grade VALUES('高二','g2',7);
INSERT INTO grade VALUES('高中','g',5);
INSERT INTO grade VALUES('高三理科','g3l',9);
INSERT INTO grade VALUES('高三文科','g3w',10);
这样数据就能插入正常。
2、对于插入数据提示:Data too long for column'name'at row1的问题
vba连接mysql数据库一个是配置文件my.ini
一个是改SQL语句加gbk
如果上面的方法都不行,那就更换MYSQL的驱动,换最新版本的驱动就好使
3、如果碰到输入一些生僻字数据库提示:Data too long for column'name'at row1错误
可以在输入数据之前加上:set names gbk
4、为什么我向MySQL数据库(5.0版本)插入记录的时候,当某个字段的内容是中文的时候就提示错误呢?解决方法如下:
create table rz_user(
id integer not null auto_increment,
name varchar(32),
password varchar(32),
primary key(id)
);
--插入语句:
set names gbk;
insert into rz_user values(1,'朋友','1123334');
解决方法是上面的:插入数据前加入:set names gbk;
5、
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论