sql distinct语句并在rails上使用多个表

时间:2012-09-24 07:12:44

标签: ruby-on-rails

你会如何用“轨道方式”写这一行?

unique_attendees = CourseSessionsUser.count_by_sql(["SELECT count(DISTINCT csu.user_id) AS count_user_id FROM course_sessions_users csu, course_sessions cs WHERE cs.course_id = ? AND csu.course_session_id = cs.id"], @course.id)

查询本身是:

SELECT count(DISTINCT csu.user_id) AS count_user_id 
FROM  course_sessions_users csu, 
      course_sessions cs 
WHERE cs.course_id = ? 
AND csu.course_session_id = cs.id

1 个答案:

答案 0 :(得分:1)

使用rails的count方法

 count = CourseSessionsUser.count('csu.user_id',
  :distinct => true, :conditions => ["cs.course_id = ?", @course.id]
  :joins => "cs LEFT JOIN course_sessions_users csu ON cs.id = csu.course_session_id")

如果条件匹配,则将直接返回非零整数,否则返回零