Procedura prosty przechowywane w MySQL:Jak wywołać procedurę przechowywaną MySQL z Rails?
CREATE PROCEDURE `proc01`()
BEGIN
SELECT * FROM users;
END
Rozpoczyna Szyny konsoli:
$ script/console
Loading development environment (Rails 2.3.5)
>> User.connection.execute("CALL proc01")
=> #<Mysql::Result:0x10343efa0>
Wygląda dobrze. ALE, więcej połączeń do tej samej procedury przechowywanej za pośrednictwem istniejącego połączenia spowoduje Commands zsynchronizowany błędu:
>> User.connection.execute("CALL proc01")
ActiveRecord::StatementInvalid: Mysql::Error: Commands out of sync; you can't run this command now: CALL proc01
from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.5/lib/active_record/connection_adapters/abstract_adapter.rb:219:in `log'
from /Library/Ruby/Gems/1.8/gems/activerecord-2.3.5/lib/active_record/connection_adapters/mysql_adapter.rb:323:in `execute'
from (irb):2
Błąd można usunąć przez „przeładować” polecenie w konsoli:
>> reload!
Reloading...
=> true
>> User.connection.execute("CALL proc01")
=> #<Mysql::Result:0x1033f14d0>
>>
Jak mogę wywołać procedurę przechowywaną MySQL z Rails?
zamieścić jakieś informacje uzupełniające w: http://www.ruby-forum.com/topic/193977#899074 (ze względu na SO nie obsługuje listing kodu w komentarzu) Może” connect! jeśli! active? "może być poprawką.Nie jestem pewien, czy jest to odpowiedź na to pytanie. – ohho
Podsumowanie w moim dzienniku sieci: http://ho.race.hk/blog/?p=231 – ohho