티스토리 뷰

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 서비스를 찾아 다시 시작 해주었다.

 

오류 해결 완료.

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/02   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28
글 보관함