Sql
mySQL 버전에 따른 쿼리문
hojomu
2023. 6. 25. 20:24
학원에서 사용하던 쿼리문을 집에서 사용하니
### Error querying database. Cause: java.sql.SQLSyntaxErrorException:
Expression 2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'control_third_project.o.order_date' which is not functionally dependent on columns in GROUP BY clause;
this is incompatible with sql_mode=only_full_group_by
다음의 에러가 발생했다.
같은 mysql이더라도, 버전이 다르면 쿼리문의 이용 방법이 조금 변하는 것 같다.
위의 문제를 해결하기 위해서
현제 session에서 어떤 모드가 작동하고 있는지 확인한 후,
SET SESSION sql_mode =
'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
이용하고 싶지 않은 기능을 제외하고 다시 sql_mode 를 설정해주는 일시적인 방법과
MySQL를 사용하는 시스템에서 my.cnf 파일에
SET SESSION sql_mode =
'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
명령어를 실행해서 영구적으로 해당 기능을 사용하지 않도록 설정할 수 있다