Project
@@sql_mode 변경 방법
Nickolodeon
2024. 5. 23. 18:41
...which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
위 에러가 발생해서, 확인해보니 full_group_by 옵션이 켜져 있어 group by 절에 없는 컬럼은 어느 부분에 표시해야 할 지 정하지 못해서 발생하는 문제라고 한다.
full_group_by 옵션을 끄기 위해, 구글링을 해봤다.
먼저 아래 쿼리로 full_group_by 옵션이 설정되어 있는지 확인했다:
쿼리: select @@sql_mode;
결과 (@@sql_mode 컬럼의 값):
ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
이후, 이를 끄기 위해 windows 내의 mysql 관련 config 설정 파일인 my.ini 를 찾아봤는데, 도저히 찾을 수가 없었다.
다음 위치에 있다고 하는데...
C:\Program Files\MySQL\MySQL Server 8.0
아무리 봐도 없었다.
다른 방법을 찾아보려고 같은 팀 동료분께 문의드렸는데, chatGPT 로 금방 찾아주셨다. 아래 쿼리로 가능하다고 한다.
SET GLOBAL sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
기존의 @@sql_mode 를 ONLY_FULL_GROUP_BY 를 제외한 나머지로 재설정하는 방식이다.
결과는 실패...
알고보니 잘못된 위치에서 my.ini 파일을 찾고 있었다.
Program Files 가 아니라 ProgramData 였다 😂
아래 위치에서 my.ini 을 발견하였다.
C:\ProgramData\MySQL\MySQL Server 8.0
my.ini 내에 다음 한 줄을 추가해주었다.
sql_mode = 'STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
이후 windows > 시스템 > 서비스에서 MySQL 서비스를 찾아 다시 시작 해주었다.
오류 해결 완료.