Tôi cần viết một script ruby độc lập để xử lý cơ sở dữ liệu. Tôi đã sử dụng mã được đưa ra bên dưới trong 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
nhưng gặp lỗi: -
`<main>': undefined method `execute' for #<ActiveRecord::ConnectionAdapters::ConnectionPool:0x00000002867548> (NoMethodError)
những gì tôi đang thiếu ở đây?
GIẢI PHÁP
Sau khi nhận được giải pháp từ denis-bu, tôi đã sử dụng nó theo cách và điều đó cũng hoạt động.
@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
hơnconnection().execute