> 데이터 베이스 > MySQL 튜토리얼 > 많은 열이 있는 테이블을 생성할 때 MySQL 오류 1118: '행 크기가 너무 큼'을 해결하는 방법은 무엇입니까?

많은 열이 있는 테이블을 생성할 때 MySQL 오류 1118: '행 크기가 너무 큼'을 해결하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-04 11:31:35
원래의
220명이 탐색했습니다.

How to Resolve MySQL Error 1118:

325개의 열이 있는 테이블을 생성할 때 오류: MySQL에서 행 크기가 너무 큼(오류 코드: 1118)

많은 수의 MySQL 테이블을 생성하려고 할 때 열 수(이 경우 325개)를 초과하면 사용자에게 "오류 코드: 1118 행 크기가 너무 큼" 오류가 발생할 수 있습니다. 이 오류는 테이블 행에 있는 데이터의 전체 크기가 데이터베이스에서 허용하는 최대 행 크기를 초과할 때 발생합니다.

이 문제를 해결하려면 다음과 같은 몇 가지 조치를 취할 수 있습니다.

  1. 열을 TEXT 또는 BLOB으로 변경: 오류 메시지에서는 열을 TEXT 또는 BLOB 데이터 유형으로 변환하여 저장 크기를 줄이도록 제안합니다. TEXT 및 BLOB 데이터 유형은 각각 대량의 비정형 데이터 또는 바이너리 데이터를 저장하도록 설계되었습니다.
  2. Barracuda 파일 형식 활성화: MySQL 구성 파일(my .ini), 사용자는 Barracuda 파일 형식으로 전환할 수 있습니다. Barracuda는 향상된 성능을 제공하고 기존 InnoDB 파일 형식에 비해 더 큰 행 크기를 지원하는 최신 파일 형식입니다.
  3. Strict 모드 비활성화: innodb_strict_mode 설정을 비활성화하여 생성을 허용할 수 있습니다. 최대 행 크기를 초과하는 테이블. 그러나 엄격 모드를 비활성화하면 경우에 따라 데이터 무결성이 손상될 수 있습니다.

제공된 예에서 사용자는 VARCHAR 열을 TEXT로 바꾸고 Barracuda를 활성화했지만 오류가 지속되었습니다. 엄격 모드를 비활성화하기 위해 innodb_strict_mode=0을 설정하여 문제가 결국 해결되었습니다. 이를 통해 최대 행 크기 제한을 초과했음에도 불구하고 테이블이 성공적으로 생성될 수 있었습니다. 엄격 모드를 비활성화하는 것은 데이터 무결성에 잠재적인 영향을 미칠 수 있으므로 최후의 수단으로 고려해야 한다는 점에 유의하는 것이 중요합니다.

위 내용은 많은 열이 있는 테이블을 생성할 때 MySQL 오류 1118: '행 크기가 너무 큼'을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿