구성 차이:
각 MyISAM은 디스크에 3개의 파일로 저장됩니다. 첫 번째 파일의 이름은 테이블 이름으로 시작하고 확장자는 파일 형식을 나타냅니다.
.frm 파일은 테이블 정의를 저장합니다.
데이터 파일 확장자는 .MYD(MYData)입니다.
인덱스 파일의 확장자는 .MYI(MYIndex)입니다.
디스크 기반 리소스는 InnoDB 테이블 공간 데이터 파일과 해당 로그 파일입니다. InnoDB 테이블의 크기는 일반적으로 2GB인 운영 체제 파일의 크기에 의해서만 제한됩니다. 성능을 강조하며 InnoDB 유형보다 실행 속도가 빠르지만 트랜잭션 지원, 외래 키 및 기타 고급 데이터베이스 기능을 제공합니다. SELECT UPDATE, INSERT, 삭제 작업. MyISAM이 더 좋습니다
AUTO_INCREMENT에 대한 작업
테이블당 하나의 AUTO_INCREMEN 열에 대한 내부 처리입니다.
MyISAM은 INSERT 및 UPDATE 작업에 대해 이 열을 자동으로 업데이트합니다. 이렇게 하면 AUTO_INCREMENT 열이 더 빨라집니다(최소 10%). 시퀀스 상단의 값이 삭제되면 다시 사용할 수 없습니다. (AUTO_INCREMENT 컬럼이 다중 컬럼 인덱스의 마지막 컬럼으로 정의된 경우, 시퀀스의 최상위에서 제거된 값을 재사용하는 것이 가능하다.)
AUTO_INCREMENT 값은 ALTER TABLE 또는 myisamch로 재설정할 수 있습니다.
AUTO_INCREMENT 유형 필드의 경우 InnoDB는 이 필드만 포함하는 인덱스를 포함해야 하지만 MyISAM 테이블에서는 다른 필드와 공동 인덱스를 설정할 수 있습니다.
더 좋습니다. 빠른 auto_increment 처리
테이블에 AUTO_INCREMENT 열을 지정하면 데이터 사전의 InnoDB 테이블 핸들에는 열에 새 값을 할당하는 데 사용되는 자동 증가 카운터라는 카운터가 포함됩니다.
자동 증가 카운터는 디스크가 아닌 메인 메모리에만 저장됩니다.
이 계산기의 알고리즘 구현은
InnoDB에서 AUTO_INCREMENT 열 작동 방식
테이블의 특정 행 수
를 참조하세요. 테이블에서 count( *)를 선택하면 MyISAM은 단순히 저장된 행 수를 읽습니다. count(*) 문에 where 조건이 포함된 경우 InnoDB는 테이블의 특정 행을 저장하지 않습니다. 즉, 테이블에서 select count(*)를 실행할 때 InnoDB는 행 수를 계산하기 위해 전체 테이블을 스캔해야 합니다lock테이블 잠금
은 행 잠금(행 수준에서 잠금)을 제공합니다. 이는 Oracle 유형 SELECT의 비잠금 읽기와 일치합니다. 또한 InnoDB 테이블의 행 잠금은 절대적이지 않습니다. MySQL이 SQL 문을 실행할 때 스캔할 범위를 결정할 수 없으면 InnoDB 테이블도 잠깁니다. 예를 들어 업데이트 테이블 세트 num=1, 여기서 이름은 "%aaa%"