2017-03-06 1 views
1

이와 같은 간단한 쿼리.왜 구문 오류입니까?

MyModel.where('student_id = :id AND from <= :date AND to >= :date', {:id => student.id, :date => day.to_s(:db)}) 

예외를

=> ActiveRecord::JDBCError: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'from <= '2017-02-28 00:00:00.000' AND to >= '2017-02-28 00:00:00.000')' 

를 돌려 그리고 난 왜하지 않습니다. 에서

+3

(당신이 열 예약어에 따라 이름을 사용하지 않는 경우 더 나은)'FROM'는 MySQL을 예약 키워드입니다 – Raptor

+0

@Raptor shoot. 이것이 제가 생각한 것입니다. 하지만 내 테이블에는 '출발'필드가 있습니다. 그러면 어떻게해야합니까? – Viktor

+0

단순 : 이름을 바꿉니다. 표 이름뿐만 아니라 열 이름에도 예약어를 사용하지 마십시오. – Raptor

답변

4

는 열 이름이있을 때 당신이 backtics를 사용해야 예약 된 단어입니다 from

MyModel.where('student_id = :id 
        AND `from` <= :date 
        AND `to` >= :date', {:id => student.id, :date => day.to_s(:db)}) 
+1

*이 문제에 대한 답을 제시 할 때 요점이 보이지 않습니다. 왜냐하면 * 동일한 * 문제가 수백 번 (SO) 해결 되었기 때문입니다. 당신 같은 사용자 (경험 + 당신은 mysql 배지 golded) 오히려 중복으로 이러한 질문을 닫아야한다. –

관련 문제