- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
将数据从 MySQL server1 迁移到 MySQL server2
server1 Ver 14.12 Distrib 5.0.51a,用于使用 readline 5.2 的 debian-linux-gnu (x86_64)
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 | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /data/mysql/gabino/share/mysql/charsets/ |
+--------------------------+------------------------------------------+
8 rows in set
server2 Ver 14.12 Distrib 5.0.90,用于使用 readline 6.0 的 pc-linux-gnu (x86_64)
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 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set
Server1 MySQL 是 Wordpress 博客的后端,前端一切正常,直到我(不幸的人)必须迁移数据,所以我登录到 PhpMyAdmin 和 MySQL 控制台。现在从后端看来,server1 中的每个东亚字符似乎都被弄乱了,无论是在控制台的 SELECT 查询中还是在 mysqldump 文件中。症状是,比如汉字看
变成了三个latin1字符看
,结果是一样的SELECT _latin1'看'
。 看
的UTF8表示是\xe7\x9c\x8b
所以MySQL以某种方式直接将每个字节显示为单独的latin1字符而不是将3个字节呈现为汉字。
即使我使用 Navicat 8 中的“数据传输”功能将两个数据库从 server1 复制到 server2 相同,在 server2 上运行的新博客也会出现乱码。 SET NAMES utf8
等各种方法都试过了,还是不行。
那么我如何告诉/强制 server1 MySQL 将 latin1 字符作为 utf8 处理并正确显示和转储它们?
最佳答案
在两台服务器上执行十六进制转储(即:SELECT HEX(columnname) FROM table
)并查看数据是否相同。如果是,那么您就会知道至少数据没有损坏。
在这种情况下,您只需为服务器设置正确的字符集和排序规则。如果不是,您可能需要重新进行数据传输,这一次请确保设置正确。
另一件事是确保浏览器的编码设置为 utf-8。
编辑:所以,数据确实在传输过程中被破坏了。 C3A7C593E280B9
是 看
的 UTF-8 表示。这可能是因为服务器 1 以 latin1 格式发送数据,而服务器 2 将其编码为 UTF-8。
在传输数据之前,您必须更改 server1 上的连接设置。为此,运行这些查询:
SET CHARACTER SET utf8; SET NAMES utf8
然后再次尝试数据传输。
编辑 2:根据您所说的,这就是我认为正在发生的事情。数据库中的数据以 UTF-8 编码。当 PHP (Wordpress) 获取此数据时,它“认为”它是用 latin1 (ISO-8859-1) 编码的,这是(不幸的)PHP 默认使用的编码。 PHP 继续将此数据提供给用户的浏览器,就好像它是用 latin1 编码的一样,但将字符编码设置为 UTF-8,用户看到的是他应该看到的。
简而言之,这是一个两错成对的案例。您现在有两个选择:
修复数据。 (即:以 UTF-8 格式读取并以 latin1 格式写回)
将服务器 2 的连接设置设置为与服务器 1 相同,这将导致数据仍然正确显示。
关于mysql - 在具有不同字符集的两个 MySQL 之间迁移数据,搞砸了 utf8,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3274261/
这是代码片段。 请说出这种用小内存存储大数据的算法是什么。 public static void main(String[] args) { long longValue = 21474836
所以我使用 imap 从 gmail 和 outlook 接收电子邮件。 Gmail 像这样编码 =?UTF-8?B?UmU6IM69zq3OvyDOtc68zrHOuc67IG5ldyBlbWFpb
很久以前就学会了 C 代码;想用 Scheme 尝试一些新的和不同的东西。我正在尝试制作一个接受两个参数并返回两者中较大者的过程,例如 (define (larger x y) (if (> x
Azure 恢复服务保管库有两个备份配置选项 - LRS 与 GRS 这是一个有关 Azure 恢复服务保管库的问题。 当其驻留区域发生故障时,如何处理启用异地冗余的恢复服务保管库?如果未为恢复服务启
说,我有以下实体: @Entity public class A { @Id @GeneratedValue private Long id; @Embedded private
我有下一个问题。 我有下一个标准: criteria.add(Restrictions.in("entity.otherEntity", getOtherEntitiesList())); 如果我的
如果这是任何类型的重复,我会提前申请,但我找不到任何可以解决我的具体问题的内容。 这是我的程序: import java.util.Random; public class CarnivalGame{
我目前正在使用golang创建一个聚合管道,在其中使用“$ or”运算符查询文档。 结果是一堆需要分组的未分组文档,这样我就可以进入下一阶段,找到两个数据集之间的交集。 然后将其用于在单独的集合中进行
是否可以在正则表达式中创建 OR 条件。 我正在尝试查找包含此类模式的文件名列表的匹配项 第一个案例 xxxxx-hello.file 或者案例二 xxxx-hello-unasigned.file
该程序只是在用户输入行数时创建菱形的形状,因此它有 6 个 for 循环; 3 个循环创建第一个三角形,3 个循环创建另一个三角形,通过这 2 个三角形和 6 个循环,我们得到了一个菱形,这是整个程序
我有一个像这样的查询字符串 www.google.com?Department=Education & Finance&Department=Health 我有这些 li 标签,它们的查询字符串是这样
我有一个带有静态构造函数的类,我用它来读取 app.config 值。如何使用不同的配置值对类进行单元测试。我正在考虑在不同的应用程序域中运行每个测试,这样我就可以为每个测试执行静态构造函数 - 但我
我正在寻找一个可以容纳多个键的容器,如果我为其中一个键值输入保留值(例如 0),它会被视为“或”搜索。 map, int > myContainer; myContainer.insert(make_
我正在为 Web 应用程序创建数据库,并正在寻找一些建议来对可能具有多种类型的单个实体进行建模,每种类型具有不同的属性。 作为示例,假设我想为“数据源”对象创建一个关系模型。所有数据源都会有一些共享属
(1) =>CREATE TABLE T1(id BIGSERIAL PRIMARY KEY, name TEXT); CREATE TABLE (2) =>INSERT INTO T1 (name)
我不确定在使用别名时如何解决不明确的列引用。 假设有两个表,a 和 b,它们都有一个 name 列。如果我加入这两个表并为结果添加别名,我不知道如何为这两个表引用 name 列。我已经尝试了一些变体,
我的查询是: select * from table where id IN (1,5,4,3,2) 我想要的与这个顺序完全相同,不是从1...5,而是从1,5,4,3,2。我怎样才能做到这一点? 最
我正在使用 C# 代码执行动态生成的 MySQL 查询。抛出异常: CREATE TABLE dump ("@employee_OID" VARCHAR(50)); "{"You have an er
我有日期 2016-03-30T23:59:59.000000+0000。我可以知道它的格式是什么吗?因为如果我使用 yyyy-MM-dd'T'HH:mm:ss.SSS,它会抛出异常 最佳答案 Sim
我有一个示例模式,它的 SQL Fiddle 如下: http://sqlfiddle.com/#!2/6816b/2 这个 fiddle 只是根据 where 子句中的条件查询示例数据库,如下所示:
我是一名优秀的程序员,十分优秀!