J'ai besoin d'écrire un script ruby autonome qui est censé traiter la base de données. J'ai utilisé le code donné ci-dessous dans les rails 3
@connection = ActiveRecord::Base.establish_connection(
:adapter => "mysql2",
:host => "localhost",
:database => "siteconfig_development",
:username => "root",
:password => "root123"
)
results = @connection.execute("select * from users")
results.each do |row|
puts row[0]
end
mais obtenir une erreur: -
`<main>': undefined method `execute' for #<ActiveRecord::ConnectionAdapters::ConnectionPool:0x00000002867548> (NoMethodError)
ce qui me manque ici?
SOLUTION
Après avoir obtenu la solution de denis-bu, je l'ai utilisée de la manière suivante et cela a également fonctionné.
@connection = ActiveRecord::Base.establish_connection(
:adapter => "mysql2",
:host => "localhost",
:database => "siteconfig_development",
:username => "root",
:password => "root123"
)
sql = "SELECT * from users"
@result = @connection.connection.execute(sql);
@result.each(:as => :hash) do |row|
puts row["email"]
end
connection.execute
plutôt queconnection().execute