加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

mysql – ActiveRecord在Ruby 1.9.2-rc1下以ASCII-8Bit返回数

发布时间:2021-03-07 23:32:45 所属栏目:编程 来源:网络整理
导读:除了问题之外,当从ActiveRecord加载数据时,尽量我尽最大全力逼迫编码,但编码始终配置为ASCII-8Bit.我已经在这里输入了尽也许具体的信息,试图成立一个可以用来辅佐我的好错误陈诉! 该项目行使以下技能: Padrino框架 Ruby 1.9.2-rc2(同样是1.9.1和1.9.2-prev
副问题[/!--empirenews.page--]

除了问题之外,当从ActiveRecord加载数据时,尽量我尽最大全力逼迫编码,但编码始终配置为ASCII-8Bit.我已经在这里输入了尽也许具体的信息,试图成立一个可以用来辅佐我的好错误陈诉!

该项目行使以下技能:

> Padrino框架
> Ruby 1.9.2-rc2(同样是1.9.1和1.9.2-preview3)
> ActiveRecord
> MySQL

(完备名单)

$bundle show | ack '(record|padrino)'
  * activerecord (2.3.8)
  * padrino (0.9.14)
  * padrino-admin (0.9.14)
  * padrino-core (0.9.14)
  * padrino-gen (0.9.14)
  * padrino-helpers (0.9.14)
  * padrino-mailer (0.9.14)

剧集表:

mysql> DESCRIBE `episodes`;
+----------------+--------------+------+-----+---------+----------------+
| Field          | Type         | Null | Key | Default | Extra          |
+----------------+--------------+------+-----+---------+----------------+
| id             | int(11)      | NO   | PRI | NULL    | auto_increment |
| show_id        | int(11)      | YES  |     | NULL    |                |
| season_id      | int(11)      | YES  |     | NULL    |                |
| episode_number | int(11)      | YES  |     | NULL    |                |
| title          | varchar(255) | YES  |     | NULL    |                |
| year           | int(11)      | YES  |     | NULL    |                |
+----------------+--------------+------+-----+---------+----------------+
6 rows in set (0.02 sec)

mysql> SHOW CREATE TABLE episodes;
       Table: episodes
Create Table: CREATE TABLE `episodes` (
  `id` int(11) NOT NULL AUTO_INCREMENT,`show_id` int(11) DEFAULT NULL,`season_id` int(11) DEFAULT NULL,`episode_number` int(11) DEFAULT NULL,`title` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,`year` int(11) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=74332 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

mysql> SHOW CREATE DATABASE development;
+-------------+--------------------------------------------------------------------------------------------------------+
| Database    | Create Database                                                                                        |
+-------------+--------------------------------------------------------------------------------------------------------+
| development | CREATE DATABASE `development` /*!40100 DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci */           |
+-------------+--------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

正如您所看到的,数据库必定以为工作应该是UTF-8;和数据库适配器:

ActiveRecord::Base.configurations[:development] = {
  :adapter   => 'mysql',:encoding  => 'utf8',:reconnect => false,:database  => "development",:pool      => 5,:username  => 'root',:password  => '',:host      => 'localhost',}

在搜查勾当记录毗连时,在节制台中回显:

ruby-1.9.2-rc1 > ActiveRecord::Base.connection
  DEBUG - [06/Jul/2010 19:24:32] "SQL (0.1ms)   SET NAMES 'utf8'"
  DEBUG - [06/Jul/2010 19:24:32] "SQL (0.1ms)   SET SQL_AUTO_IS_NULL=0"
 => #

ruby-1.9.2-rc1>的ActiveRecord :: Base.connection.encoding

Ruby应该知道说话,这是我的$locale

LANG="en_GB.UTF-8"
LC_COLLATE="en_GB.utf-8"
LC_CTYPE="en_GB.utf-8"
LC_MESSAGES="en_GB.utf-8"
LC_MONETARY="en_GB.utf-8"
LC_NUMERIC="en_GB.utf-8"
LC_TIME="en_GB.utf-8"
LC_ALL=

固然Ruby没有配置Encoding.default_internal:

$irb --simple-prompt
ruby-1.9.2-rc1 > Encoding.default_internal
 => nil 

我在我的应用措施的config / boot.rb中添加了一个片断,如下所示:

if Kernel.const_defined?("Encoding") and Encoding.respond_to?(:find) and Encoding.respond_to?(:default_internal)
  Encoding.default_internal = Encoding.find('UTF-8')
end

这完全切合您的预期……可是是黑客进攻,并没有办理题目.

这是现场题目的输出:

ruby-1.9.2-rc1 > e = Episode.new
  DEBUG - [06/Jul/2010 19:29:14] "SQL (0.1ms)   SET NAMES 'utf8'"
  DEBUG - [06/Jul/2010 19:29:14] "SQL (0.1ms)   SET SQL_AUTO_IS_NULL=0"
  DEBUG - [06/Jul/2010 19:29:14] "Episode Columns (0.8ms)   SHOW FIELDS FROM `episodes`"
 => #

我通过包围会见器取得了一些乐成,并将它们从头界说为:

class Episode 
  # ...
  def title
    title.encode!
  end
  # ...
end

那边编码!界说为here in the API docs for 1.9 – 在此引用它“没有选项返回str转码为Encoding.default_internal的副本.”

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读