Не удалось подключить mysql из драгоценного камня Sequel

Когда я пытаюсь подключиться к MySQL из Sequel. Я получаю эти ошибки:

require 'rubygems'
        require 'sequel'
        DB = Sequel.connect(:adapter => 'mysql', :user => 'root', :host => 'localhost', :database => 'scanty',:password=>'xx')
        DB.tables
    Sequel::DatabaseConnectionError: NameError uninitialized constant Mysql::CLIENT_MULTI_RESULTS
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/adapters/mysql.rb:98:in `connect'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/database.rb:92:in `initialize'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:166:in `call'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:166:in `make_new'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:153:in `available'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:144:in `acquire'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:143:in `synchronize'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:143:in `acquire'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/connection_pool.rb:105:in `hold'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/database.rb:471:in `synchronize'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/adapters/mysql.rb:128:in `execute'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/dataset.rb:314:in `execute'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/adapters/mysql.rb:342:in `execute'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/adapters/mysql.rb:298:in `fetch_rows'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/dataset.rb:185:in `each'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/dataset/convenience.rb:156:in `map'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/dataset/convenience.rb:156:in `map'
        from /opt/local/lib/ruby/gems/1.8/gems/sequel-3.2.0/lib/sequel/adapters/shared/mysql.rb:60:in `tables'
        from (irb):6irb(main):007:0> Sequel::DatabaseConnectionError: NameErro

person Subba Rao    schedule 17.07.2009    source источник
comment
Кажется, что ваша ошибка усечена? Кроме того, где хост в вашем вызове функции?   -  person Artem Russakovskii    schedule 17.07.2009
comment
я добавил хост, но он все еще выдает ту же ошибку   -  person Subba Rao    schedule 17.07.2009


Ответы (2)


Вам необходимо установить собственный драйвер MySQL, чистый рубиновый драйвер не совместим с Sequel.

В зависимости от вашей установки Ruby может быть достаточно просто выполнить gem install mysql. Однако, если чистый файл Ruby mysql.rb уже находится в вашем пути загрузки Ruby, вам нужно либо удалить его из пути загрузки, либо использовать gem('mysql') перед вызовом Sequel.connect.

person Jeremy Evans    schedule 04.08.2009

Вам не хватает :host=>'localhost' или чего-то еще, что у вас есть.

Кроме того, и это чисто из соображений производительности, вы должны попытаться включить :compress. Это может сэкономить ТОННУ пропускной способности.

http://sequel.rubyforge.org/rdoc/files/doc/opening_databases_rdoc.html

Изменить: хорошо, если это не хост, возможно, это конфликт? См. http://groups.google.com/group/sequel-talk/browse_thread/thread/ee39640a92351f1?pli=1. Также http://www.mail-archive.com/[email protected]/msg02275.html

person Artem Russakovskii    schedule 17.07.2009
comment
спасибо, у меня на машине установлены две версии mysql gem. - person Subba Rao; 17.07.2009