MySQL sql_mode 수정 이 적용 되 지 않 는 원인 및 해결

7329 단어 MySQLsql 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 수정 이 적용 되 지 않 는 자 료 는 우리 의 다른 관련 글 을 주목 하 세 요!

좋은 웹페이지 즐겨찾기