> 데이터 베이스 > MySQL 튜토리얼 > 모델을 사용하지 않고 Rails 3에서 사용자 정의 SQL 쿼리를 실행하는 방법은 무엇입니까?

모델을 사용하지 않고 Rails 3에서 사용자 정의 SQL 쿼리를 실행하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-12-26 15:27:14
원래의
766명이 탐색했습니다.

How to Execute Custom SQL Queries in Rails 3 Without Using a Model?

모델이 없는 Rails 3 사용자 정의 SQL 쿼리

Rails 3에서는 모델을 사용하지 않고 사용자 정의 SQL 쿼리를 실행할 수 있습니다. 데이터베이스에 대한 연결. 그러나 제공하신 코드에서 실행 메서드 관련 문제가 발생했습니다.

이 문제를 해결하려면 다음 접근 방식을 사용할 수 있습니다.

  1. ActiveRecord를 사용하여 데이터베이스에 대한 연결을 설정합니다.: Base.configure_connection.
  2. 다음을 사용하여 연결 개체를 검색합니다. ActiveRecord::Base.connection.
  3. connection.execute를 사용하여 사용자 지정 SQL 쿼리를 실행합니다.

다음은 이러한 변경 사항을 통합하는 수정된 코드 버전입니다.

@connection = ActiveRecord::Base.establish_connection(
  :adapter => "mysql2",
  :host => "localhost",
  :database => "siteconfig_development",
  :username => "root",
  :password => "root123"
)

results = @connection.connection.execute("select * from users")
results.each do |row|
  puts row[0]
end
로그인 후 복사

또는 제공된 솔루션에서 제안한 대로 :as => :hash 옵션을 사용하여 결과를 반복하면서 이름으로 열에 액세스합니다.

@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
로그인 후 복사

이 접근 방식을 사용하면 모델에 의존하지 않고 직접 사용자 지정 SQL 쿼리를 실행할 수 있습니다.

위 내용은 모델을 사용하지 않고 Rails 3에서 사용자 정의 SQL 쿼리를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿