rails3 mysql2安装,incompatible character encodings: UTF-8 and ASCII-8BIT 解决!

本文主要是介绍rails3 mysql2安装,incompatible character encodings: UTF-8 and ASCII-8BIT 解决!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题环境:

os:  windows XP

 

F:\>ruby -v

ruby 1.9.2p180 (2011-02-18) [i386-mingw32]

 

 

 

F:\>rails -v

Rails 3.0.5

 

 

问题描述:

1、安装不了mysql2

      rails3 默认使用mysql adapter是mysql2. 

   1) gem install mysql2

         ERROR:  Error installing mysql2:

         The 'mysql2' native gem requires installed build tools.

 

        Please update your PATH to include build tools or download the DevKit

        from 'http://rubyinstaller.org/downloads' and follow the instructions

        at 'http://github.com/oneclick/rubyinstaller/wiki/Development-Kit'

 

   2) 安装DevKit  按照http://wuhuizhong.iteye.com/blog/875493

 

   3)gem install mysql2

         Temporarily enhancing PATH to include DevKit...

        Building native extensions.  This could take a while...

        ERROR:  Error installing mysql2:

        ERROR: Failed to build gem native extension.

 

        F:/Ruby192/bin/ruby.exe extconf.rb

       checking for rb_thread_blocking_region()... yes

       checking for main() in -llibmysql... no

         *** extconf.rb failed ***

Could not create Makefile due to some reason, probably lack of

necessary libraries and/or headers.  Check the mkmf.log file for more

details.  You may need configuration options.

 

    4)这样问题就同 http://www.iteye.com/problems/49494

    5)那就暂且使用mysql  adapter吧

       gemfile 中改为: gem 'mysql', '2.8.1'

2.incompatible character encodings: UTF-8 and ASCII-8BIT

    当页面中写了中文之后,比如一个label, <%= f.label :title, '标题' %>

    按错误信息google ,baidu了 n多,都没有解决。包括:

    1) html.erb文件前加这一行:<%# encoding:utf-8 %> ,并保存成了utf-8格式(这一点是需要的)

    2) http://www.iteye.com/topic/355909 这个第一点试过了,第二点找不到类似的文件

 

    后来发现 new页面可以正常显示,edit页面报这个错,同是一个_form.html.erb

 

    按一篇文章中说法,测试了下:

   页面代码:

   <td><%= blog.title.encoding %></td>

 

    页面显示:ASCII-8BIT

    说明:因为rails从数据库取出的中文默认编码是ASCII-8BIT,如果页面是UTF-8编码,  concat就会出现这个错误。

 

  要解决这个问题,就需要“数据库取出的中文 转为utf-8”. 找不到可用的资料。

 

解决

    感谢QQ网友 寿司   告诉我windows下安装mysql2的命令:

    gem install mysql2 -v 0.2.6 --platform x86-mingw32

 

    成功安装了mysql2,  将gemfile中改为:gem 'mysql2', '0.2.6'  

    database.yml 中adapter 改回mysql2

 

    再次测试:页面代码:<td><%= blog.title.encoding %></td>

    result:  UTF-8.

 

    第2个问题也迎刃而解了。再次感谢 寿司。


 

补充:

   看来mysql2 adapter还是有bug, 一个表有5列:

  A: id   B:string  C:integer  D:string  E:string

  从数据库查出,B列utf-8, 显示正常, D,E  却是ASCII-8BIT。

 

   我重建了数据库表,调整了列的顺序,改为:

   A: id   B:string   D:string  E:string C:integer 

  从数据库查出,B,D列utf-8, 显示正常, E  还是ASCII-8BIT。

 

    再重建一次,,改为:

   A: id   B:string   D:string  E:string C:integer 

   这次,从数据库查出,B,D,E列utf-8,都显示正常了

 

2011-04-17 补充:

  今天遇到了这个错误:invalid date   

  http://hot88zh.iteye.com/blog/858300

  按以上博文中的方法:复制Mysql5 server端的libmysql.dll文件,到Ruby安装目录下的bin文件夹中,即可解决~

 

  之前使用mysql adapter时,ruby bin下的libmysql.dll 是一个早期版本,现在用mysql2 adapter,就需要用mysql 5 server下的libmysql.dll

 

 

 

这篇关于rails3 mysql2安装,incompatible character encodings: UTF-8 and ASCII-8BIT 解决!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/246414

相关文章

SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题

《SpringBoot利用dynamic-datasource-spring-boot-starter解决多数据源问题》dynamic-datasource-spring-boot-starter是一... 目录概要整体架构构想操作步骤创建数据源切换数据源后续问题小结概要自己闲暇时间想实现一个多租户平台,

VSCode中C/C++编码乱码问题的两种解决方法

《VSCode中C/C++编码乱码问题的两种解决方法》在中国地区,Windows系统中的cmd和PowerShell默认编码是GBK,但VSCode默认使用UTF-8编码,这种编码不一致会导致在VSC... 目录问题方法一:通过 Code Runner 插件调整编码配置步骤方法二:在 PowerShell

mybatis-plus分页无效问题解决

《mybatis-plus分页无效问题解决》本文主要介绍了mybatis-plus分页无效问题解决,原因是配置分页插件的版本问题,旧版本和新版本的MyBatis-Plus需要不同的分页配置,感兴趣的可... 昨天在做一www.chinasem.cn个新项目使用myBATis-plus分页一直失败,后来经过多方

电脑开机提示krpt.dll丢失怎么解决? krpt.dll文件缺失的多种解决办法

《电脑开机提示krpt.dll丢失怎么解决?krpt.dll文件缺失的多种解决办法》krpt.dll是Windows操作系统中的一个动态链接库文件,它对于系统的正常运行起着重要的作用,本文将详细介绍... 在使用 Windows 操作系统的过程中,用户有时会遇到各种错误提示,其中“找不到 krpt.dll”

Pycharm安装报错:Cannot detect a launch configuration解决办法

《Pycharm安装报错:Cannotdetectalaunchconfiguration解决办法》本文主要介绍了Pycharm安装报错:Cannotdetectalaunchconfigur... 本文主要介绍了Pycharm安装报错:Cannot detect a launch configuratio

pytorch+torchvision+python版本对应及环境安装

《pytorch+torchvision+python版本对应及环境安装》本文主要介绍了pytorch+torchvision+python版本对应及环境安装,安装过程中需要注意Numpy版本的降级,... 目录一、版本对应二、安装命令(pip)1. 版本2. 安装全过程3. 命令相关解释参考文章一、版本对

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

大数据spark3.5安装部署之local模式详解

《大数据spark3.5安装部署之local模式详解》本文介绍了如何在本地模式下安装和配置Spark,并展示了如何使用SparkShell进行基本的数据处理操作,同时,还介绍了如何通过Spark-su... 目录下载上传解压配置jdk解压配置环境变量启动查看交互操作命令行提交应用spark,一个数据处理框架

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Flask解决指定端口无法生效问题

《Flask解决指定端口无法生效问题》文章讲述了在使用PyCharm开发Flask应用时,启动地址与手动指定的IP端口不一致的问题,通过修改PyCharm的运行配置,将Flask项目的运行模式从Fla... 目录android问题重现解决方案问题重现手动指定的IP端口是app.run(host='0.0.