安装在MySQL4.1的453h出现问题的解决
创始人
2024-06-30 22:50:26
0

以下的文章主要是对解决453h安装在MySQL4.1 以上的UTF8数据库,在实际运行中所造成的乱码问题与安装失败的问题解答,以下就是文章的具体内容的描述,望你在浏览之后会对其实际操作有所了解。

这几天在尝试安装mambo 4.53h版, 由于我的数据库是mysq4.1以上版本,并且设定的字符集是UTF8 。在尝试安装了几次后发现以下几种情况:

 

1. 将数据库设置为 latin1 , 不修改任何文件,在安装时无论选择gb2312 还是utf8,都可以完成安装,并且网页显示正常,但是通过phpmyadmin看数据表时发现,里面所有中文全部为乱码,也就是说,通过latin1字符集保存,可以正常显示中文网页,但是实际上在数据库中中文是乱码。

而且不能通过phpmyadmin备份(备份出来的文件,无论改成什么编码,里面中文均为乱码)。所以这不是王道,我没有做选择考虑。

2. 将数据库字符集设置成utf8, 不修改任何文件,在安装时无论选择gb2312还是utf8,都出现 1071 specified key too long max length 1000 bytes 的错误。并且只要是数据库字符集设置成utf8,(utf8是一个 character set 作为 3 bytes存储,latin1 是作为1 bytes存储),无论是按照论坛中的一些意见,修改 installation/sql/mambo.sql 还是别的文件, 都会出现key 超过1000bytes的错误,安装不能继续。

我本意是要安装manbo的中文utf8版本,以方便和别的程序整合。所以在查询了google,论坛和其他一些资料后,经过尝试,终于以我的想法,以选择 manbo的utf8 字符集 在MySQL4.1以上,并且字符集也是utf8 的数据库中安装成功。

网页显示中文正常,无乱码,并且用phpmyadmin查询数据库表时,所有中文也都显示正常,并且以utf8保存。以下是我的解决方法,仅供参考:

 

首先设置数据库字符集为utf8,

 

 

 

  1. CODE:[Copy to clipboard]ALTER DATABASE DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci 

 

或者通过phpmyadmin里面直接改也一样。

 

 

修改 installation/sql/mambo.sql 文件:

 

查找将所有的

 

 

  1. CODE:[Copy to clipboard]TYPE=MyISAM;  

 

替换成

 

 

 

  1. CODE:[Copy to clipboard]TYPE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;  

 

查找

 

 

 

  1. CODE:[Copy to clipboard]UNIQUE KEY `section_value_value_aro` (`section_value`,`value`)  

 

 

 

 

  1. CODE:[Copy to clipboard]UNIQUE KEY `#__gacl_section_value_value_aro` (`section_value`,`value`),  

 

并将这2行代码用 # 注释掉,或者删除,whatever~~

 

在这一段代码下面,也就是

 

 

  1. CODE:[Copy to clipboard]# Table structure for table `#__core_acl_aro_groups`  

 

上面,按顺序增加以下4行代码:

 

 

CODE:[Copy to clipboard]ALTER TABLE `#__core_acl_aro` CHANGE `section_value` `section_value` VARCHAR( 240 ) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL default '0';

 

CODE:[Copy to clipboard]ALTER TABLE `#__core_acl_aro` CHANGE `value` `value` VARCHAR( 240 ) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL default '';

CODE:[Copy to clipboard]ALTER TABLE `#__core_acl_aro` ADD UNIQUE `section_value_value_aro` ( `section_value` , `value` );

CODE:[Copy to clipboard]ALTER TABLE `#__core_acl_aro` ADD UNIQUE `#__gacl_section_value_value_aro` (`section_value`,`value`);

 

修改 includes/database.php 文件:

查找

 

 

 

  1. CODE:[Copy to clipboard]$this->_table_prefix = $table_prefix;  

 

在该行代码下面添加以下三行代码:

 

 

 

  1. CODE:[Copy to clipboard]MySQL(和PHP搭配之***组合)_query("SET NAMES 'utf8'", $this->_resource);   
  2. CODE:[Copy to clipboard]MySQL(和PHP搭配之***组合)_query("SET CHARACTER SET utf8", $this->_resource);  
  3. CODE:[Copy to clipboard]MySQL(和PHP搭配之***组合)_query("SET COLLATION_CONNECTION='utf8_general_ci'", $this->_resource);  

 

修改后保存。

 

 

安装的时候,选择UTF8作为编码格式安装。

 

如此修改后能够正常安装,并且在数据库中的中文显示和保存都正常,如果需要整合discuz或者其他程序的时候,也能够选择UTF8版本,并且整合后不会出现在注册时使用中文用户名,但是注册后显示为乱码的现象。

注意事项

经本方法修改后,请在升级manbo的时候,对 includes/database.php 做相应的修改,否则会出错。

 

以上修改方法是我参考了论坛中的几位达人以及通过google搜索查到的一些英文资料,还有TW manbo的一些资料后,经过尝试完成修改并经测试没有问题的。希望对碰到同样问题的朋友有些用处!觉得有用的朋友顶一下,要对得起我写的那么多东西啊。

 

以上的相关内容就是对解决453h安装在MySQL4.1的介绍,望你能有所收获。 

【编辑推荐】

  1. MySQL字符集中所设定参数
  2. 列举MySQL出错代码的列表
  3. MySQL 5.0新特性教程之存储过程
  4. MySQL初学者的必备3要素
  5. MySQL维护与实际应用的设计笔记简介

 

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
Intel将Moblin社区控... 本周二,非营利机构Linux基金会宣布,他们将担负起Moblin社区的管理工作,而这之前,Mobli...