学习脚步--- 以MYSQL为数据库的程序中的乱码问题

                             MYSQL为数据库的程序中的乱码问题

本人是初学者很多知识的总结还不完善,但是为了个人学习,所以进行了总结。有什么不对的请大家指教!

一、两种查看MYSQL编码的方式:

1status

         可以查看MYSQL对数据库默认的字符编码,use 某个数据库后,则显示这个数据库的编码

2. show variables like 'character\_set\_%';

     可以查看更详细的信息:

    character_set_server:设置服务器使用的字符集

character_set_client :设置客户端发送查询使用的字符集

character_set_connection :设置服务器需要将收到的查询串转换成的字符集

character_set_results :设置服务器要将结果数据转换到的字符集,转换后才发送给客户端

二、如何比较有效的避免乱码?

注意:要避免乱码,就要全面的进行预防,从MYSQL数据库的默认编码、命令操作的地方、建数据库设置、建表设置、程序设置。

1.在安装MYSQL数据库的时候不要一下子默认到底,要特别留心使用的字符编码,将其设置为UTF8(这个传说在实际中比GBK用的要多),省得以后麻烦。

2.可以在终端写create database aubergine character set utf8;建立数据库,但是,不建议在终端建表,尤其是向表中insert数据,因为从终端插入的数据和系统平台的编码有关,容易产生乱码。所以,1>传说程序员有个习惯,在向数据库插入数据的时候,是将建表、插入语句写入.sql文件中,然后在MYSQL的终端建立好数据库后source一下这个.sql文件;

那么,还有一种方法,2>使用MyEclipse开发的,可以在MyEclipse中建立数据库连接后,建立一个SQL EDITOR,将建表、插入语句写进去,点击绿色的三角运行。

3.剩下的就是写法上注意的了:----插入数据

1>打开MYSQL的终端,建立数据库,使用source命令往数据库中建表并插入数据

        create database aubergine default character set utf8;

        use aubergine;

        set names utf8;

        source E:/aubergine.sql;

        注意:查了一下资料说set names utf8;相当于下面的三条命令:

set character_set_client=utf8;

set character_set_connection=utf8;

set character_set_results=utf8;

            aubergine.sql中如何写来达到对表的字符编码的设置呢?

DROP  TABLE IF  EXISTS  kang;

CREATE  TABLE  kang (

id  int(12)  NOT  NULL  auto_increment,

order_id  int(10)  unsigned  NOT  NULL,

product_id  int(10) unsigned  NOT  NULL,

dang_price  double  NOT  NULL,

product_num  int(10) unsigned  NOT  NULL  default  '1',

amount  double  NOT  NULL,

PRIMARY  KEY  (id)

) ENGINE=InnoDB  DEFAULT  CHARSET=utf8;

设置数据库存储引擎默认的的数据库字符编码是utf8,这个就是对表进行的字符编码设置。

注:如果使用的MyEclipse中的DB Browser来插入数据,那么在写url的时候要写作:

jdbc:mysql://localhost:3306/aubergine?characterEncoding=utf8

 4.程序中的写法注意:

1>Jdbc连接数据库的时候在指定url的时候标注(由于是mysql数据库所以utf8之间没有横杠)

String url="jdbc:mysql://localhost:3306/auber?characterEncoding=gbk";

(如果使用utf-8编码  String url="jdbc:mysql://localhost:3306/auber?characterEncoding=utf8";)

2> request.setCharacterEncoding(utf-8)----------------------》可以使用过滤器来实现

3> <meta http-equiv="content-type" content="text/html;charset=gbk">

meta是用来在HTML文档中模拟HTTP协议的响应头报文。meta 标签用于网页的<head></head>中。

4> response.setContentType( "text/html;charset=UTF-8 ");//jsp代码处写的

5> <%@ page contentType="text/html;charset=GB2312" pageEncoding="GB2312"%>//jsp文件的头部写的

6>有时候method=”post”没错,可能get有错则:更改tomcat---àconfig--àserver.xml里面的编码(URLEncoder是个很好用的)

<Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

               redirectPort="8443" />

改为

<Connector port="8080" protocol="HTTP/1.1"

               connectionTimeout="20000"

redirectPort="8443"

urlencoding="utf-8"/>

补充:如果在安装MYSQL数据库的时候就是默认的Latin文怎么办?

mysql安装后的目录中找到my.ini文件,然后把里面的default-character-set=LATIAN改成default-character-set=GBK 或者是UTF-8

这个在你的电脑上存在其他项目的时候不建议使用,因为更改这个会影响到其他项目的编码。 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值