mysql乱码处理
mysql数据库乱码问题

数据库读出乱码解决一、分析常见数据库问题修改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去连接结果发现出了很多问题,主要集中在乱码显示上面,实际开发中,想必这类问题是见怪不怪了。
JSP+MySQL中文乱码问题post提交乱码解决方案

JSP+MySQL中⽂乱码问题post提交乱码解决⽅案写了两个jsp页⾯index.jsp和mysql_insert.jsp。
数据处理流程为:在浏览器(chrome)上访问index.jsp后在其表单上输⼊数据,提交⾄mysql_insert.jsp,mysql_insert.jsp⾸先将接收到的数据按变量存⼊MySQL的html_db数据库的person_tb中(该表原有部分数据),然后mysql_insert.jsp再拿出该表中所有数据显⽰在mysql_insert.jsp页⾯上。
现在发现,当提交的数据中含有中⽂(⽐如变量姓名的值为中⽂)时,mysql_insert.jsp页⾯上显⽰新增的那条记录中的相应中⽂(姓名的值)乱码,其他数据都显⽰正常,查看数据库,发现也是相应的含有中⽂的变量值(姓名的值)乱码。
乱码情况如下图:index.jsp中第⼀⾏有语句:<%@ page contentType="text/html;charset=gb2312"%> ,在浏览器(chrome)中访问此页⾯时⽆乱码(主要指中⽂乱码,英⽂乱码现象还没遇见过)。
(试过将gb2312换成utf-8,访问后中⽂乱码)mysql_insert.jsp中第⼀⾏有语句:<%@page language="java" pageEncoding="UTF-8"%>,在浏览器中直接访问此页⾯时⽆乱码。
mysql_insert.jsp页⾯的代码如下:复制代码代码如下:<%@page language="java" pageEncoding="UTF-8"%><%@ page import="java.sql.*" %><HTML><HEAD><TITLE>add message into table </TITLE></HEAD><BODY><%String id=request.getParameter("id"); //从表单获得String name=request.getParameter("name"); //从表单获得String sex=request.getParameter("sex"); //从表单获得String age=request.getParameter("age"); //从表单获得try{/** 连接数据库参数 **/String driverName = "com.mysql.jdbc.Driver"; //驱动名称String DBUser = "root"; //mysql⽤户名String DBPasswd = "123456"; //mysql密码String DBName = "html_db"; //数据库名String connUrl = "jdbc:mysql://localhost/" + DBName + "?user=" + DBUser + "&password=" + DBPasswd;Class.forName(driverName).newInstance();Connection conn = DriverManager.getConnection(connUrl);Statement stmt = conn.createStatement();stmt.executeQuery("SET NAMES UTF8");String insert_sql = "insert into person_tb values('" + id + "','" + name + "','" + sex + "','" + age + "')";String query_sql = "select * from person_tb";try {stmt.execute(insert_sql);}catch(Exception e) {e.printStackTrace();}try {ResultSet rs = stmt.executeQuery(query_sql);while(rs.next()) {%>ID:<%=rs.getString("id")%> </br>姓名:<%=rs.getString("name")%> </br>性别:<%=rs.getString("sex")%> </br>年龄:<%=rs.getString("age")%> </br> </br><%}}catch(Exception e) {e.printStackTrace();}//rs.close();stmt.close();conn.close();}catch (Exception e) {e.printStackTrace();}%></body></html>我的数据库设置的是全部使⽤UTF-8编码,如下图:我的虚拟⽬录下的web.xml内容如下:tomcat/conf⽬录下的server.xml⽂件的内容如下:复制代码代码如下:<U><?xml version='1.0' encoding='utf-8'?></U><Server port="8005" shutdown="SHUTDOWN"><Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> <Listener className="org.apache.catalina.core.JasperListener" /><Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> <GlobalNamingResources><Resource name="UserDatabase" auth="Container"type="erDatabase"description="User database that can be updated and saved"factory="ers.MemoryUserDatabaseFactory"pathname="conf/tomcat-users.xml" /></GlobalNamingResources><Service name="Catalina"><Connector port="8080" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443" /><Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /><Engine name="Catalina" defaultHost="localhost"><Realm className="org.apache.catalina.realm.LockOutRealm"><Realm className="erDatabaseRealm" resourceName="UserDatabase"/></Realm><Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true"> <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" prefix="localhost_access_log." suffix=".txt"pattern="%h %l %u %t "%r" %s %b" /></Host></Engine></Service></Server>tomcat/conf⽬录下web.xml⽂件的主要内容如下:复制代码代码如下:<U><?xml version="1.0" encoding="UTF-8"?></U><web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/xml/ns/javaee/web-app_3_0.xsd"version="3.0"><servlet><servlet-name>default</servlet-name><servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class><init-param><param-name>debug</param-name><param-value>0</param-value></init-param><init-param><param-name>listings</param-name><param-value>false</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet><servlet-name>jsp</servlet-name><servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class><init-param><param-name>fork</param-name><param-value>false</param-value></init-param><init-param><param-name>xpoweredBy</param-name><param-value>false</param-value></init-param><load-on-startup>3</load-on-startup></servlet><servlet-mapping><servlet-name>default</servlet-name><url-pattern>/</url-pattern></servlet-mapping><!-- The mappings for the JSP servlet --><servlet-mapping><servlet-name>jsp</servlet-name><url-pattern>*.jsp</url-pattern><url-pattern>*.jspx</url-pattern></servlet-mapping><session-config><session-timeout>30</session-timeout></session-config><此处省略了mime-mapping的内容><welcome-file-list><welcome-file>index.html</welcome-file><welcome-file>index.htm</welcome-file><welcome-file>index.jsp</welcome-file></welcome-file-list></web-app>现在我能想到的设置编码的地⽅也就只有这么多了,其他还有哪⾥需要设置编码?恳求指导。
MySQL中的错误处理与异常处理技巧

MySQL中的错误处理与异常处理技巧引言:MySQL作为一种关系型数据库管理系统,在数据存储和访问方面具有广泛的应用。
然而,在使用MySQL过程中,错误和异常是无法避免的。
因此,了解MySQL中的错误处理和异常处理技巧变得非常重要。
本文将探讨MySQL中常见的错误类型、错误处理的方法和异常处理的技巧,帮助读者更好地理解和处理MySQL中的问题。
一、MySQL中的错误类型1. 语法错误:语法错误是最常见的错误类型之一。
当用户执行一条SQL语句,但语法错误时,MySQL将无法正确解析该语句,并返回相应的错误信息。
例如,在执行SELECT语句时,如果缺少FROM关键字,就会出现语法错误。
2. 数据类型错误:MySQL有许多数据类型,如整型、浮点型、字符串等。
如果用户在执行SQL 语句时,将错误的数据类型分配给某一字段,将会触发数据类型错误。
例如,将一个字符串值插入到整型字段中。
3. 空指针错误:当用户在执行SQL语句时,引用了一个空指针时,将会出现空指针错误。
例如,如果用户执行了一个SELECT语句,但该语句所查询的表不存在,则会触发空指针错误。
二、错误处理的方法1. 错误代码:在MySQL中,每个错误都有一个对应的错误代码。
当执行一条SQL语句时,如果出现错误,MySQL会返回一个错误代码。
用户可以通过判断该错误代码,从而进行相应的错误处理。
例如,错误代码为1062表示重复键值错误。
2. 错误消息:除了错误代码外,MySQL还会返回相应的错误消息。
错误消息通常包含了错误的详细信息,如错误的原因、出错的位置等。
用户可以通过错误消息来定位错误,并采取相应的处理措施。
3. 日志文件:MySQL还提供了日志文件功能,记录了MySQL的运行状态、执行的SQL语句等信息。
用户可以通过查阅日志文件,找到出错的原因,并进行相应的错误处理。
在配置MySQL服务器时,可以设置不同级别的错误日志,以满足不同的需求。
三、异常处理的技巧1. 异常处理语句:在MySQL中,用户可以使用BEGIN和END关键字来定义一段代码块。
MYSQL数据库使用UTF-8中文编码乱码的解决办法

MYSQL数据库使⽤UTF-8中⽂编码乱码的解决办法1.⽤phpmyadmin创建数据库和数据表创建数据库的时候,请将“整理”设置为:“utf8_general_ci”或执⾏语句:复制代码代码如下:CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;创建数据表的时候:如果是该字段是存放中⽂的话,则需要将“整理”设置为:“utf8_general_ci”,如果该字段是存放英⽂或数字的话,默认就可以了。
相应的SQL语句,例如:CREATE TABLE `test` (`id` INT NOT NULL ,`name` VARCHAR( 10 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,PRIMARY KEY ( `id` )) ENGINE = MYISAM ;2.⽤PHP读写数据库在连接数据库之后:复制代码代码如下:$connection = mysql_connect($host_name, $host_user, $host_pass);加⼊两⾏:mysql_query("set character set 'utf8'");//读库mysql_query("set names 'utf8'");//写库就可以正常的读写MYSQL数据库了。
⽤的appserv-win32-2.5.10做的环境,装这个包的时候⽤默认的utf8编码。
在写数据库连接⽂件时,写成:$conn = mysql_connect("$host","$user","$password");mysql_query("SET NAMES 'UTF8'");mysql_select_db("$database",$conn);然后在做页⾯时,注意这句:复制代码代码如下:<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />这样不管输⼊数据库的中⽂,还是页⾯显⽰,就都正常了。
数据库中乱码问题解决方案

数据库中乱码问题解决方案数据库中乱码问题是一个常见的问题,特别是在多语言环境下。
在这种情况下,有时候我们会发现数据库中存储的数据出现乱码,这可能导致数据的有效性受到影响。
以下是一些解决方案,可以帮助您解决这个问题。
1. 确认数据库的字符集在创建数据库的时候,需要确认数据库的字符集是否正确。
如果字符集不正确,那么在存储数据的时候就会出现乱码问题。
可以通过以下查询语句来查看数据库的字符集:SHOW VARIABLES LIKE 'character_set_database';如果发现字符集有误,可以通过以下语句来修改数据库的字符集:ALTER DATABASE database_name CHARACTER SET utf8;2. 确认连接字符集连接字符集也可能导致乱码问题。
如果您的连接字符集与数据库字符集不同,那么在查询数据时就会出现乱码问题。
可以通过以下语句来查询连接字符集:SHOW VARIABLES LIKE 'character_set_connection';如果连接字符集有误,可以通过以下语句来修改连接字符集:SET NAMES utf8;3. 确认表的字符集在创建表的时候,需要确认表的字符集是否正确。
如果表的字符集不正确,那么在存储数据的时候就会出现乱码问题。
可以通过以下语句来查询表的字符集:SHOW CREATE TABLE table_name;如果发现字符集有误,可以通过以下语句来修改表的字符集:ALTER TABLE table_name CONVERT TO CHARACTER SET utf8;4. 确认字段的字符集在创建字段的时候,需要确认字段的字符集是否正确。
如果字段的字符集不正确,那么在存储数据的时候就会出现乱码问题。
可以通过以下语句来查询字段的字符集:SHOW FULL COLUMNS FROM table_name;如果发现字符集有误,可以通过以下语句来修改字段的字符集:ALTER TABLE table_name MODIFY column_name varchar(255) CHARACTER SET utf8;5. 确认应用程序的字符集除了数据库和连接字符集之外,应用程序的字符集也需要与数据库的字符集相同。
MySQL中文乱码问题的解决方法

MySQL中文乱码问题的解决方法在使用MySQL数据库过程中,经常会遇到中文乱码的问题。
这是由于MySQL默认使用的字符集是Latin1,而大部分中文系统使用的是UTF-8字符集所致。
本文将介绍在MySQL中解决中文乱码问题的几种方法。
一、修改MySQL配置文件MySQL配置文件(f)是MySQL服务器的设置文件,通过修改该文件可以改变MySQL的默认字符集。
在Linux系统中,该文件通常位于/etc/mysql/f或者/etc/f。
在Windows系统中,该文件通常位于MySQL安装目录下的my.ini文件。
步骤如下:1. 找到f或my.ini文件并打开。
2. 在[mysqld]部分添加或修改以下内容:```[mysqld]character-set-server=utf8collation-server=utf8_general_ci```3. 保存文件并重启MySQL服务。
二、修改数据库、数据表、字段字符集如果修改MySQL配置文件没有解决中文乱码问题,可以尝试直接修改数据库、数据表、字段字符集。
1. 修改数据库字符集可以使用ALTER DATABASE语句修改数据库的字符集。
例如:```ALTER DATABASE database_name CHARACTER SET utf8 COLLATEutf8_general_ci;```2. 修改数据表字符集可以使用ALTER TABLE语句修改数据表的字符集。
例如:```ALTER TABLE table_name CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;```3. 修改字段字符集可以使用ALTER TABLE语句修改字段的字符集。
例如:```ALTER TABLE table_name MODIFY column_name VARCHAR(255) CHARACTER SET utf8 COLLATE utf8_general_ci;```其中,table_name为表名,column_name为字段名。
史上最全的PHP+MySql中文乱码解决方案

我相信PHPmyadmin里查看是乱码,调用出来的话肯定100%也是乱码。
乱码问题其实也就是编码不一致导致的。
要解决这个问题需要回顾乱码问题出现以前的操作是否使用的是同一种编码。
总之一句话,要解决PHP中文乱码最好最快的解决办法就是:页面申明的编码与数据库内部编码一致,如果页面申请的页码与数据库内部编码不一致时,就设定连接编码mysql_query(”SET NAMES XXX”); XXX为连接编码。
一定可以解决乱码的问题。
在mysql+php程序开发中,总结了产生乱码原因:mysql数据库默认的编码是utf8,如果这种编码与你的PHP网页不一致,可能就会造成MYSQL乱码.MYSQL中创建表时会让你选择一种编码,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.MYSQL创建表时添加字段是可以选择编码的,如果这种编码与你的网页编码不一致,也可能造成MYSQL乱码.用户提交页面的编码与显示数据的页面编码不一致,就肯定会造成PHP页面乱码.如用户输入资料的页面是big5码, 显示用户输入的页面却是gb2312,这种100%会造成PHP页面乱码.PHP页面字符集不正确.PHP连接MYSQL数据库语句指定的编码不正确.一.首先是PHP网页的编码1. php文件本身的编码与网页的编码应匹配a. 如果欲使用gb2312编码,那么php要输出头:header(“Content-Type: text/html; charset=gb2312″),静态页面添加<metahttp-equiv=”Content-Type” content=”text/html; charset=gb2312″>,所有文件的编码格式为ANSI,可用记事本打开,另存为选择编码为ANSI,覆盖源文件。
b. 如果欲使用utf-8编码,那么php要输出头:header(“Content-Type: text/html; charset=utf-8″),静态页面添加<metahttp-equiv=”Content-Type” content=”text/html; charset=utf-8″>,所有文件的编码格式为utf-8。
彻底解决MySql在UTF8字符集下乱码问题 - mysql

为了顺利的开发一个多语言的国际化J2EE程序,需要修改数据库字符集,我的做法如下:安装MySq时选择字符集为UTF-8修改MySql安装目录下的my.ini中配置的默认编码:该文件中有两处这样的配置:default-character-set=latin1将这两处改成:default-character-set=utf8新建数据库需指定字符集:UTF8: CREATE DA TABASE mmtye DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;在命令行查看字符集编码:show variables like '%char%'; 会看到如下信息:character_set_client | utf8character_set_connection | utf8character_set_database | utf8character_set_filesystem | binarycharacter_set_results | utf8character_set_server | utf8character_set_system | utf8character_sets_dir | D:\MySQL\share\charsets\以上内容在重启MySql后也一直有效,无需每次启动数据库都要指定。
A、为了在命令行下能正确查看中文,命令行下执行:set character_set_results=gbk;B、若需要在windows命令行执行insert、update,则执行:set character_set_client=gbk;A、B 两个命令重启数据库前有效,重启后就失效了。
MYSQL的乱码问题,总结了一下几个处理方法:1:改变数据库的默认编码配置,在MYSQL的安装目录中,找到my.ini,修改默认编码为:default-character-set=utf82:建立数据库时,CREATE DATABASE ms_db CHARACTER SET utf8 COLLATEutf8_general_ci;3:执行脚本:指定编码格式set names utf8(注意,不是UTF-8)4:如果你采用的是外部接入的方式,在连接中确定请求的编码格式如:jdbc:mysql://localhost:3306/ms_db?useUnicode=true&characterEncoding=U TF-8(不要出现任何空格,否则出错)。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
用MS SQL和oracle9 太吃内存,有点大,全给卸载了.安装了mysql占内存小,方便使用!version:mysql-essential-5.1.36在MySQL Command Line Client显示中文一切正常;在eclipse中新工程,连接到mysql,读取一个表显示:代码:package com.mch.mysql;import java.sql.Connection;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.sql.Statement;public class Mysql1 {public static void main(String[] args) {String url ="jdbc:mysql://localhost/test";String user="root";String password="******";try {Class.forName("org.gjt.mm.mysql.Driver").newInstance();Connection conn= DriverManager.getConnection(url,user,password);Statement stmt = conn.createStatement();ResultSet rs = stmt.executeQuery("select * from pet");while(rs.next()){System.out.print("name:" + rs.getString(1));System.out.print("\t所有者:" + rs.getString(2));System.out.print("\tbirth:" + rs.getString("birth"));System.out.println();}rs.close();stmt.close();conn.close();} catch (InstantiationException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();} catch (ClassNotFoundException e) {e.printStackTrace();} catch (SQLException e) {e.printStackTrace();}}}显示乱码?号.name:?í?í所有者:?????? birth:2007-08-21 name:???? 所有者:?????? birth:2007-06-12 name:?? 所有者:?????? birth:2007-08-21 name:°??? 所有者:???? birth:1999-03-30 name:Puffball 所有者:Diane birth:1999-03-30 在网上查了下,很多人都有这个问题,大部分人说修改my.ini文件,//原文件[client]port=3306[mysql]default-character-set=latin1[mysqld]port=3306default-character-set=latin1我把:default-character-set=utf-8[两处,大小写都试过]mysql不能启动.再改成default-character-set=gb2312可以正常启动,但在MySQL Command Line Client显示乱码,eclipse输出也是码乱.查了下mysql支持字符集,得到default-character-set=utf8要这样设置,中间没有杠[-],查看mysql使用的编码:引用:mysql> show variables like 'character\_set\_%';+--------------------------+--------+| Variable_name | Value |+--------------------------+--------+| character_set_client | utf8 || character_set_connection | utf8 || character_set_database | utf8 || character_set_filesystem | binary || character_set_results | utf8 || character_set_server | utf8 || character_set_system | utf8 |+--------------------------+--------+7 rows in set (0.00 sec)mysql>插入数据:引用:mysql> insert into event values("猪猪",'2009-02-21',"发烧","打针就好了!");ERROR 1366 (HY000): Incorrect string value: '\xD6\xED\xD6\xED' for column 'name'at row 1mysql> insert into event values("zhu",'2009-02-21',"fashao","da zhen jiu hao le!");Query OK, 1 row affected (0.06 sec)插入中文失败,插入英文可以.查看看显示:引用:mysql> select * from pet-> ;+----------+--------------+----------+------+------------+-------+| name | owner | species | sex | birth | death |+----------+--------------+----------+------+------------+-------+| 脰铆脰铆| 脥玫脮帽露芦| 脰铆| n | 2007-08-21 | NULL | | 鲁卢鲁卢| 脥玫脮帽露芦| 鹿路| n | 2007-06-12 | NULL | | 脫茫| 脥玫脮帽露芦| 脫茫| t | 2007-08-21 | NULL | | 掳垄脜拢| 脩么脥镁| 脜拢| F | 1999-03-30 | NULL | | Puffball | Diane | hamster | f | 1999-03-30 | NULL || bile | Hane | defaster | f | 2004-09-30 | NULL |+----------+--------------+----------+------+------------+-------+6 rows in set (0.00 sec)另默认的那个字符集是8859-1,在这个状态下可以输入汉字.很怪,可能很简单,新手就是不会......再次作测试:default-character-set=gb2312ERROR 1366 (HY000): Incorrect string value: '\xB9\xD8\xD3\xF0' for column 'name' at row 1向表中插入中文字符时,出现错误。
mysql> select * from pet;+--------+--------+---------+------+------------+------------+| name | owner | species | sex | birth | death |+--------+--------+---------+------+------------+------------+| ?í?í | ?????? | ?í| ? | 2007-08-21 | 0000-00-00 || ???? | ?????? | ?? | ? | 2007-06-12 | 0000-00-00 || ?? | ?????? | ?? | | 2007-08-21 | 0000-00-00 |+--------+--------+---------+------+------------+------------+3 rows in set (0.02 sec)表中的中文字符位乱码。
解决办法:使用命令:mysql> status;--------------C:\Program Files\MySQL\MySQL Server 5.1\bin\mysql.exe Ver 14.14 Distrib 5.1.36for Win32 (ia32)Connection id: 1Current database: test1Current user: root@localhostSSL: Not in useUsing delimiter: ;Server version: 5.1.36-community MySQL Community Server (GPL) Protocol version: 10Connection: localhost via TCP/IPServer characterset: gb2312Db characterset: latin1Client characterset: gb2312Conn. characterset: gb2312TCP port: 3306Uptime: 6 min 31 secThreads: 1 Questions: 15 Slow queries: 0 Opens: 20 Flush tables: 1 Open ta les: 9 Queries per second avg: 0.38--------------查看mysql发现Db characterset的字符集设成了latin1,所以出现中文乱码。