数据库读出乱码解决一、分析常见数据库问题修改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显示更多的字符,要显示简体码的繁体字,就只能用GBK7.JSP连接MYSQL数据库语句指定的编码不正确8.JSP页面没有指定数据提交的编码,就会造成乱码:所以,JSP乱码的原因无非就是以上几种,知道原因之后,要解决JSP乱码的方法也容易多了我们一一来表达:1.如果安装mysql的编码已不能更改,很多朋友是购买虚拟主机建立网站,无权更改MYSQL的安装编码,这一关我们可以跳过,因为只要后面的步聚正确,一样能解决乱码问题2.修改数据库编码,如果是数据库编码不正确:可以在phpmyadmin执行如下命令:ALTER DATABASE`test`DEFAULT CHARACTER SET utf8COLLATE utf8_bin以上命令就是将test数据库的编码设为utf83.修改表的编码:ALTER TABLE`category`DEFAULT CHARACTER SET utf8COLLATE utf8_bin以上命令就是将一个表category的编码改为utf84.修改字段的编码:ALTER TABLE`test`CHANGE`dd``dd`VARCHAR(45)CHARACTER SET utf8COLLATEutf8_bin NOT NULL以上命令就是将test表中dd的字段编码改为utf85.如果是这种情况容易解决,只需检查下页面,修改源文件的charset即可,//这个正确就无问题了6.这种情况也是修改页面charset即可,7.在JSP连接数据库的语句中,private String url="jdbc:mysql://localhost/"+DB_NAME+"user="+LOGIN_NAME+"&password="+LOGIN_PASSWORD+"&characterEncoding=GBK";//相键要看characterEncoding8.这种乱码的情况,只需在页面开头加上request.setCharacterEncoding("GBK");指定提交的即可注意:按照以上方法修改以后只能保证你新插入的数据不会乱码,举个例:如果你用户已提交的数据是BIG5,你却想通过以上方法改为可以在GB2312的网页正确显示是不可能的,这种文字内码的变换只能通过另写程序来解决,请其它相关文章总结:先要判断JSP乱码是插入数据库之后乱码,还是JSP页面刚提交过来就乱码了,如果JSP 刚接收上一页面的数据显示就乱码了,肯定是字符集不对,可者没有加request.setCharacterEncoding("GBK");如果是数据库的原因就参考上面的2,3,4种方法可能是编码问题这样连接一下数据库看看jdbc:mysql://localhost:3306/xxxx useUnicode=true&characterEncoding=UTF-8看看能否有效果二、乱码案例使用MYSQL数据库,用JSP去连接结果发现出了很多问题,主要集中在乱码显示上面,实际开发中,想必这类问题是见怪不怪了。
正在装载数据……搜索了互联网上面很多的帖子,反复推敲,有几点心得写下来,以后碰到类似的问题,也防止自己忘记要重新来过:/fly29/archive/2004/07/31/57084.aspx刚开始学JSP,就碰到中文乱码问题,在CSDN上看了不少帖子,有点小的启示,还好问题解决了。
今天是碰到关于页面传值,进行显示中文出现乱码的问题。
------------------------------name:Email:<%@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,DBMS...学习中...上面这篇文章是我搜索了很多文章中选出来的,他说得很明白了,乱码问题主要原理就像上面所说的,页面传值问题。
下面的总结得也很好:一)JSP中文乱码问题解决方法小结/chm_y/archive/2004/07/03/33277.aspx在使用JSP的过程中,最使人头疼的一个问题就是中文乱码问题,以下是我在软件开发中遇到的乱码问题以及解决方法。
1、JSP页面乱码这种乱码的原因是应为没有在页面里指定使用的字符集编码,解决方法:只要在页面开始地方用下面代码指定字符集编码即可:<%@page contentType="text/html;charset=gb2312"language="java"import="java.sql.*"errorPage="err.jsp"%>2、数据库乱码这种乱码会使你插入数据库的中文变成乱码,或者读出显示时也是乱码,解决方法如下:在数据库连接字符串中加入编码字符集StringUrl="jdbc:mysql://localhost/digitgulf?user=root&password=root&useUnicode=true&characterEncoding=GB2312";并在页面中使用如下代码:response.setContentType("text/html;charset=gb2312");request.setCharacterEncoding("gb2312");3、中文作为参数传递乱码当我们把一段中文字符作为参数传递个另一页面时,也会出现乱码情况,解决方法如下:在参数传递时对参数编码,比如RearshRes.jsp?keywords="+.URLEncoder.encode(keywords)然后在接收参数页面使用如下语句接收keywords=new String(request.getParameter("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 DEFAULTCHARSET=gb2312这段信息重要的部分在于后面的:“DEFAULT CHARSET=gb2312”,如果不是这个信息,而是“DEFAULT CHARSET=latin1”,则直接在数据库执行插入包含中文的数据(insert into test values('中国'))将会出现乱码,通过JSP执行插入中文数据到MYSQL也是一样乱码,所以我改成我上面所示的CHARSET才行(DEFAULT CHARSET=gb2312)。