提交 f1a184fe 编写于 作者: J Jeremy Kemper

MySQL: introduce :encoding option to specify the character set for client,...

MySQL: introduce :encoding option to specify the character set for client, connection, and results.  Only available for MySQL 4.1 and later with the mysql-ruby driver.  Do SHOW CHARACTER SET in mysql client to see available encodings.  Closes #2975.

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3152 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
上级 65806622
*SVN*
* MySQL: introduce :encoding option to specify the character set for client, connection, and results. Only available for MySQL 4.1 and later with the mysql-ruby driver. Do SHOW CHARACTER SET in mysql client to see available encodings. #2975 [Shugo Maeda]
* Add tasks to create, drop and rebuild the MySQL and PostgreSQL test databases. [Marcel Molina Jr.]
* Correct boolean handling in generated reader methods. #2945 [don.park@gmail.com, Stefan Kaes]
......
......@@ -38,7 +38,17 @@ def self.mysql_connection(config) # :nodoc:
mysql = Mysql.init
mysql.ssl_set(config[:sslkey], config[:sslcert], config[:sslca], config[:sslcapath], config[:sslcipher]) if config[:sslkey]
ConnectionAdapters::MysqlAdapter.new(mysql.real_connect(host, username, password, database, port, socket), logger, [host, username, password, database, port, socket])
if config[:encoding]
begin
mysql.options(Mysql::SET_CHARSET_NAME, config[:encoding])
rescue
raise ActiveRecord::ConnectionFailed, 'The :encoding option is only available for MySQL 4.1 and later with the mysql-ruby driver. Again, this does not work with the ruby-mysql driver or MySQL < 4.1.'
end
end
conn = mysql.real_connect(host, username, password, database, port, socket)
conn.query("SET NAMES '#{config[:encoding]}'") if config[:encoding]
ConnectionAdapters::MysqlAdapter.new(conn, logger, [host, username, password, database, port, socket], mysql)
end
end
......@@ -87,9 +97,10 @@ class MysqlAdapter < AbstractAdapter
"MySQL server has gone away"
]
def initialize(connection, logger, connection_options=nil)
def initialize(connection, logger, connection_options=nil, mysql=Mysql)
super(connection, logger)
@connection_options = connection_options
@mysql = mysql
end
def adapter_name #:nodoc:
......@@ -119,12 +130,21 @@ def native_database_types #:nodoc
# QUOTING ==================================================
def quote(value, column = nil)
if value.kind_of?(String) && column && column.type == :binary
s = column.class.string_to_binary(value).unpack("H*")[0]
"x'#{s}'"
else
super
end
end
def quote_column_name(name) #:nodoc:
"`#{name}`"
end
def quote_string(string) #:nodoc:
Mysql::quote(string)
@mysql.quote(string)
end
def quoted_true
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册