[mysql] SELECT 목록이 GROUP BY 절에없고 집계되지 않은 열이 포함되어 있습니다. sql_mode = only_full_group_by와 호환되지 않습니다.

WAMP Server가 설치된 Windows PC에서 MySQL 5.7.13을 사용하는 오전

여기 내 문제는이 쿼리를 실행하는 동안입니다.

SELECT *
FROM `tbl_customer_pod_uploads`
WHERE `load_id` = '78' AND
      `status` = 'Active'
GROUP BY `proof_type`

항상 이와 같은 오류가 발생합니다.

SELECT 목록의 식 # 1이 GROUP BY 절에없고 GROUP BY 절의 열에 기능적으로 종속되지 않는 집계되지 않은 열 ‘returntr_prod.tbl_customer_pod_uploads.id’를 포함합니다. 이것은 sql_mode = only_full_group_by와 호환되지 않습니다.

최선의 해결책을 말씀해 주시겠습니까?

결과가 필요합니다.

+----+---------+---------+---------+----------+-----------+------------+---------------+--------------+------------+--------+---------------------+---------------------+
| id | user_id | load_id | bill_id | latitude | langitude | proof_type | document_type | file_name    | is_private | status | createdon           | updatedon           |
+----+---------+---------+---------+----------+-----------+------------+---------------+--------------+------------+--------+---------------------+---------------------+
|  1 |       1 | 78      | 1       | 21.1212  | 21.5454   |          1 |             1 | id_Card.docx |          0 | Active | 2017-01-27 11:30:11 | 2017-01-27 11:30:14 |
+----+---------+---------+---------+----------+-----------+------------+---------------+--------------+------------+--------+---------------------+---------------------+



답변

SELECT 목록의 식 # 1이 GROUP BY 절에없고 GROUP BY 절의 열에 기능적으로 종속되지 않는 집계되지 않은 열 ‘returntr_prod.tbl_customer_pod_uploads.id’를 포함합니다. 이것은 sql_mode = only_full_group_by와 호환되지 않습니다.

이 명령으로 MySQL에서 SQL 모드를 변경하면 간단히 해결할 수 있습니다.

SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

이것도 나를 위해 작동합니다 .. 내 프로젝트에는 이와 같은 쿼리가 많기 때문에이 SQL 모드를 only_full_group_by로 변경했기 때문에 이것을 사용했습니다.

감사합니다… 🙂


답변

MySQL의 only_full_group_by모드가 켜져 있으면 .NET Framework를 사용할 때 엄격한 ANSI SQL 규칙이 적용됩니다 GROUP BY. 당신이 경우 쿼리에 관해서는,이 수단는 것을 GROUP BYproof_type열, 당신은 두 가지를 선택할 수 있습니다 :

  • proof_type열 또는
  • 다른 열의 집계

다른 컬럼의 “집계”, 나는 같은 집계 함수를 사용하여 의미 MIN(), MAX()또는 AVG()다른 열이. 따라서 귀하의 경우 다음 쿼리가 유효합니다.

SELECT proof_type,
       MAX(id) AS max_id,
       MAX(some_col),
       MIN(some_other_col)
FROM tbl_customer_pod_uploads
WHERE load_id = '78' AND
      status = 'Active'
GROUP BY proof_type

대부분의 MySQL GROUP BY내가 보는 질문은 엄격 모드가 꺼져 있으므로 쿼리가 실행되지만 잘못된 결과가 나타납니다. 귀하의 경우 쿼리가 전혀 실행되지 않으므로 실제로 수행하려는 작업에 대해 생각해야합니다.

참고 : ANSI SQL은 선택되는 GROUP BY열에 기능적으로 종속 된 열을 포함하여 선택이 허용되는 항목을 확장합니다 . 기능적 종속성의 예는 테이블의 기본 키 열을 기준으로 그룹화하는 것입니다. 기본 키는 모든 레코드에 대해 고유함이 보장되므로 다른 열의 값도 결정됩니다. MySQL은이를 허용하는 데이터베이스 중 하나입니다 (SQL Server 및 Oracle은 AFAIK가 아님).


답변

하나의 솔루션 사용

(1) PHPMyAdmin

phpMyAdmin을 사용하는 경우 아래 스크린 샷에 언급 된대로 ” sql_mode “설정 을 변경합니다 .
여기에 이미지 설명 입력

“sql 모드”변수를 편집하고 값에서 “ONLY_FULL_GROUP_BY”텍스트를 제거하십시오.

(2) SQL / 명령 프롬프트
아래 명령을 실행합니다.

SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

(삼) SELECT *를 사용하지 마십시오.

SELECT 쿼리에서 관련 열을 사용하십시오. 관련이란 “group by”절 또는 집계 함수 (MAX, MIN, SUM, COUNT 등)가있는 열에 나오는 열을 의미합니다.


중요 사항

point (1) 또는 point (2)를 사용하여 변경 한 내용은 영구적으로 설정되지 않으며 다시 시작할 때마다 되돌아갑니다.

따라서 구성 파일 (예 : [mysqld] 섹션의 /etc/mysql/my.cnf)에서이를 설정해야 MySQL을 다시 시작한 후에도 변경 사항이 적용됩니다.

구성 파일 : /etc/mysql/my.cnf

변수 이름 : sql_mode 또는 sql-mode


답변

아래 방법은 내 문제를 해결했습니다.

우분투에서

유형: sudo vi /etc/mysql/my.cnf

A를 입력하여 삽입 모드로 들어갑니다.

마지막 줄에 두 줄 코드 아래에 붙여 넣습니다.

[mysqld]
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

esc를 입력하여 입력 모드를 종료합니다.

Type :wq to save and close vim.

sudo service mysql restartMySQL을 다시 시작하려면 입력하십시오 .


답변

일부 명령으로 sql_mode = only_full_group_by 를 비활성화
할 수 있습니다. 터미널 또는 MySql IDE에서 시도 할 수 있습니다.

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';

mysql> set session 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 단계:

sudo vi /etc/mysql/mysql.conf.d/mysqld.cnf

2 단계 : 마지막 줄로 이동하여 다음을 추가합니다.

sql_mode = ""

3 단계 : 저장

4 단계 : mysql 서버를 다시 시작합니다.


답변

쿼리가 SQL92에서 유효하려면 이름 열이 선택 목록에서 생략되거나 GROUP BY 절에서 이름이 지정되어야합니다.

SQL99 이상에서는 기능적으로 GROUP BY 열에 종속 된 경우 선택적 기능 T301 당 이러한 비 집계를 허용합니다. 이름과 custid간에 이러한 관계가 존재하는 경우 쿼리가 합법적입니다. 예를 들어, 고객의 기본 키로 관리 된 경우입니다.

MySQL 5.7.5 이상은 기능 의존성 감지를 구현합니다. ONLY_FULL_GROUP_BY SQL 모드가 활성화 된 경우 (기본값) MySQL은 선택 목록, HAVING 조건 또는 ORDER BY 목록이 GROUP BY 절에 이름이 지정되지 않았거나 기능적으로 종속되지 않은 집계되지 않은 열을 참조하는 쿼리를 거부합니다. .

MySQL을 통해 :: MySQL 5.7 참조 ​​설명서 :: 12.19.3 GROUP BY의 MySQL 처리

다음 명령으로 SQL 모드를 변경하여 해결할 수 있습니다.

SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

그리고 … 데이터베이스를 다시 연결하는 것을 잊지 마십시오 !!!