MySQL sql_mode 수정 이 적용 되 지 않 는 원인 및 해결
최근 여러 차례 sqlmode 의 화제 도 여러 번 관련 문 제 를 만 났 습 니 다.오늘 은 쇠뿔 도 단 김 에 빼 서 여러분 에 게 sql 을 가 져 다 드 리 겠 습 니 다.모드 의 사례 공유.
장면 시 뮬 레이 션
업무 민감 성 을 고려 하여 아래 와 관련 된 표,저장 과정 등 은 모두 진실 한 데이터 가 아니 지만 조사 과정 에 영향 을 주지 않 는 다.
(1)고객 측 에서 아동 화 를 개발 하여 저장 과정 을 만 들 었 는데 이 저장 과정 은 group by 표준 문법 을 엄 격 히 지 키 지 않 았 다.
session 1:
mysql> delimiter //
mysql> create procedure test_for_group_by()
-> begin
-> select k,pad,count(*) from test.test group by k;
-> end //
Query OK, 0 rows affected (0.01 sec)
mysql> delimiter ;
(2)고객 측 에서 아동 화 를 개발 하여 이 저장 과정 을 호출 하여 ERROR 1140 을 잘못 보고 합 니 다.그 당시 저장 과정 이 비교적 복잡 하고 개조 하기 가 비교적 번 거 로 웠 기 때문에 고객 측 에서 sql 을 수정 하 는 것 을 선택 했다.mode
session 1:
mysql> call test_for_group_by();
ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'test.test.k'; this is incompatible with sql_mode=only_full_group_by
(3)고객 측 수정 sqlmode,다시 실행,여전히 오류 보고 ERROR 1140
session 2:
mysql> set global sql_mode='STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';
Query OK, 0 rows affected (0.00 sec)
session 1:
mysql> call test_for_group_by();
ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'test.test.k'; this is incompatible with sql_mode=only_full_group_by
(4)이때 시스템 변 수 를 수정 하면 새 연결 에 만 효과 가 있 고 기 존 연결 에 도움 이 되 지 않 는 다 고 생각 합 니 다.그래서 고객 에 게 새로운 연결 구축 에 중심 을 두 고 시스템 변수 가 효력 이 발생 했 는 지 확인 하고 저장 과정 을 다시 호출 하 라 고 했 지만 ERROR 1140 을 잘못 보 고 했 습 니 다.몇 번 반복 시도 한 것 은 모두 이 결과 입 니 다.
session 3:
mysql> show variables like 'sql_mode';
+---------------+------------------------------------------------------------------------------------------------------------------------+
| Variable_name | Value |
+---------------+------------------------------------------------------------------------------------------------------------------------+
| sql_mode | STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+---------------+------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.01 sec)
mysql> call test_for_group_by();
ERROR 1140 (42000): In aggregated query without GROUP BY, expression #1 of SELECT list contains nonaggregated column 'test.test.k'; this is incompatible with sql_mode=only_full_group_by
(5)고객 측 이 이 세 션 에서 비표 준 적 인 group by 문 구 를 실행 할 수 있 도록 더욱 조사 한 결과 정상적으로 실행 할 수 있 음 을 발견 했다.
session 3:
mysql> select user,host,count(*) From mysql.user group by user;
+---------------+-----------+----------+
| user | host | count(*) |
+---------------+-----------+----------+
| mysql.session | localhost | 1 |
| mysql.sys | localhost | 1 |
| root | localhost | 1 |
| rpl_user | % | 1 |
| test | % | 1 |
+---------------+-----------+----------+
5 rows in set (0.00 sec)
(6)계속 조사 한 결과 이 저장 과정의 sqlmode,아니면 ONLY 포함FULL_GROUP_BY,이 로 인해 시행 오류
session 2:
mysql> select routine_catalog,routine_schema,routine_name,routine_type,created,last_altered,sql_mode from routines where routine_name='test_for_group_by';
+-----------------+----------------+-------------------+--------------+---------------------+---------------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| routine_catalog | routine_schema | routine_name | routine_type | created | last_altered | sql_mode |
+-----------------+----------------+-------------------+--------------+---------------------+---------------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| def | test | test_for_group_by | PROCEDURE | 2020-12-24 12:12:10 | 2020-12-24 12:12:10 | ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION |
+-----------------+----------------+-------------------+--------------+---------------------+---------------------+-------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
(7)여기 서 우 리 는 시스템 변수 수정 이 새 대상 에 게 만 유효 하고 기 존 대상 에 게 는 유효 하지 않다 는 것 을 알 수 있다.해결 방법 은 매우 간단 하 니,이 저장 과정 을 재건 하면 된다.
session 3:
mysql> drop procedure test_for_group_by;
Query OK, 0 rows affected (0.01 sec)
mysql> delimiter //
mysql> create procedure test_for_group_by()
-> begin
-> select k,pad,count(*) from test.test group by k;
-> end //
Query OK, 0 rows affected (0.01 sec)
mysql> delimiter ;
mysql> call test_for_group_by();
+--------+-------------------------------------------------------------+----------+
| k | pad | count(*) |
+--------+-------------------------------------------------------------+----------+
| 393975 | 35227182905-15234265621-59793845249-15413569710-23749555118 | 1 |
| 495688 | 09512147864-77936258834-40901700703-13541171421-15205431759 | 1 |
| 497896 | 13152283289-69561545685-52868757241-04245213425-69280254356 | 1 |
| 498573 | 43131080328-59298106536-35954612339-97546855884-75769514803 | 1 |
| 500775 | 27590239742-20204899609-34345212327-79811525340-24267764271 | 1 |
| 501885 | 63188288836-92351140030-06390587585-66802097351-49282961843 | 1 |
| 503330 | 01495266405-82925129145-92643983850-90243995398-18709399387 | 1 |
| 503666 | 40929980986-33813039690-13155419391-97985458477-39771362212 | 1 |
| 504353 | 00505722282-72931248925-57037623248-81117963809-88658076981 | 1 |
| 514246 | 21979564480-87492594656-60524686334-78820761788-57684966682 | 1 |
+--------+-------------------------------------------------------------+----------+
10 rows in set (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
총결산이 사례 를 통 해 우 리 는 sql 을 수정 하 는 것 을 알 수 있다.mode 시스템 변 수 는 새 연결 과 새 대상(주로 함수 와 저장 과정 포함)에 만 유효 하 며,기 존 연결 과 기 존 대상 에 대해 서 는 유효 하지 않 습 니 다.
이상 은 MySQL sqlmode 수정 이 적용 되 지 않 는 원인 및 해결 에 대한 자세 한 내용 은 MySQL sqlmode 수정 이 적용 되 지 않 는 자 료 는 우리 의 다른 관련 글 을 주목 하 세 요!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Redash를 사용할 때 몰랐던 SQL을 쓰는 법을 배웠습니다.최근 redash에서 sql을 쓸 기회가 많고, 이런 쓰는 방법이 있었는지와 sql에 대해 공부를 다시하고 있기 때문에 배운 것을 여기에 씁니다. Redash란? 월별로 데이터를 표시하고 싶습니다 주별로 데이터를 표...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.