[php] Laravel 5.4: Specified key was too long error
첨부 '1' |
|
---|
Laravel 5.4: Specified key was too long error
Laravel 5.4 made a change to the default database character set, and it’s now utf8mb4 which includes support for storing emojis. This only affects new applications and as long as you are running MySQL v5.7.7 and higher you do not need to do anything.
For those running MariaDB or older versions of MySQL you may hit this error when trying to run migrations:
[Illuminate\Database\QueryException]
SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table users add unique users_email_unique(email))
[PDOException]
SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes
As outlined in the Migrations guide to fix this all you have to do is edit your AppServiceProvider.php file and inside the boot method set a default string length:
Laravel 5.4 에서 기본 데이터베이스 캐릭터셋이 변경됐고, utf8mb4 이모티콘을 지원한다.
이것은 새로운 프로젝트에 영향을 미치며 MySQL 5.7.7 이상이라면 아무것도 할 필요 없다.
MariaDB 또는 이전 버전의 MySQL을 사용하면 마이그레이션을 실행할 때 오류가 발생할 수 있다.
Migrations 가이드에 안내한대로 다음과 같이 AppServiceProvider.php 파일을 편집하여 기본 문자열 길이를 설정하면 된다.
# app/Providers/AppServiceProvider.php
use Illuminate\Support\Facades\Schema; public function boot() { Schema::defaultStringLength(191); }
After that everything should work as normal.
[출처] https://laravel-news.com/laravel-5-4-key-too-long-error
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
23 | Database | [mysql] MySQL 데이터베이스 추가 및 사용자 추가 | hooni | 2019.11.22 | 673 |
22 | Database | [oracle] Oracle 사용자 추가 절차 | hooni | 2019.11.22 | 625 |
21 | Database | [mysql] MySQL 백업 및 복구 | hooni | 2019.11.22 | 827 |
20 | Database | [mysql] MySql DB/테이블 사이즈 확인을 위한 쿼리 | hooni | 2019.11.22 | 666 |
19 | Database | SQL JOIN 정리 (Inner Join & Outer Join) | hooni | 2019.11.22 | 1845 |
18 | Database | [mysql] MacOS에 MySQL 설치, 설정, 암호 재설정 | hooni | 2017.12.15 | 1474 |
17 | Database | [mysql] ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement. | hooni | 2017.12.15 | 1215 |
16 | Database | [mysql] MySQL 한글 깨짐 현상 해결하기(UTF8) | hooni | 2017.12.01 | 5484 |
15 | Database | [mysql] 중복데이터 삭제하는 초간단 쿼리 | hooni | 2017.11.22 | 3434 |
14 | Database | [mysql] 쿼리 실행시 ERROR 1366 (HY000) : incorrect string value : for column 3 | hooni | 2017.03.30 | 8791 |
13 | Database | [mysql] CPU 점유율이 높을 때 확인할 내용 | hooni | 2015.08.26 | 6655 |
12 | Database | [mysql] MySql 에서 정렬 후 그룹 하는 방법 | hooni | 2015.05.07 | 3012 |