sql_mode에서 my.cnf
(Windows 시스템용 my.ini) 파일을 찾아 mysql 설치에 STRICT_TRANS_TABLES을 추가하세요. 추가되지 않은 경우에는 엄격하지 않은 모드를 의미합니다. 예를 들어 엄격 모드가 켜져 있음을 의미합니다. sql_mode=NO_ENGINE_SUBSTITUTION,
2. 엄격 모드 기능 설명
자체 증가 필드에 "값" 삽입을 지원하지 않습니다
않습니다 기본값이 있는 텍스트 필드 지원
3 .예:
<span style="color: rgb(0, 0, 0);">CREATE TABLE `mytable` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) NOT NULL, `content` text NOT NULL, PRIMARY KEY (`id`)<br/>) ENGINE=InnoDB DEFAULT CHARSET=utf8;</span>
1.not null 필드 삽입 null 값 테스트
In non-strict 모드에서 실행됨
<span style="color: rgb(0, 0, 0);">mysql> insert into mytable(content) values('programmer');<br/>Query OK, 1 row affected, 1 warning (0.00 sec)mysql> select * from mytable;<br/>+----+------+------------+| id | name | content |<br/>+----+------+------------+| 1 | | programmer |<br/>+----+------+------------+1 row in set (0.00 sec)</span>
로 변환되었습니다. 엄격 모드에서 실행됨
<span style="color: rgb(0, 0, 0);">mysql> insert into mytable(content) values('programmer');ERROR 1364 (HY000): Field 'name' doesn't have a default value</span>
2. 자동 증가 필드에 대한 "값 테스트" 삽입
비엄격 모드에서 실행
<span style="color: rgb(0, 0, 0);">mysql> insert into mytable(id,name,content) value('','fdipzone','programmer');<br/>Query OK, 1 row affected, 1 warning (0.00 sec)mysql> select * from mytable;<br/>+----+----------+------------+| id | name | content |<br/>+----+----------+------------+| 1 | fdipzone | programmer |<br/>+----+----------+------------+1 row in set (0.00 sec)</span>
엄격 모드에서 실행
<span style="color: rgb(0, 0, 0);">mysql> insert into mytable(id,name,content) value('','fdipzone','programmer');<br/>ERROR 1366 (HY000): Incorrect integer value: '' for column 'id' at row 1</span>
<span style="color: rgb(0, 0, 0);">mysql> insert into mytable(id,name,content) value(null,'fdipzone','programmer');<br/>Query OK, 1 row affected (0.00 sec)mysql> select * from mytable;<br/>+----+----------+------------+| id | name | content |<br/>+----+----------+------------+| 1 | fdipzone | programmer |<br/>+----+----------+------------+1 row in set (0.00 sec)</span>
필드 ID가 NULL이면 성공적으로 실행할 수 있습니다.
3. 텍스트 필드 기본값 테스트
비엄격 모드에서 실행
<span style="color: rgb(0, 0, 0);">mysql> CREATE TABLE `mytable` ( -> `id` int(11) NOT NULL AUTO_INCREMENT, -> `name` varchar(20) NOT NULL, -> `content` text NOT NULL default '', -> PRIMARY KEY (`id`) -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8;Query OK, 0 rows affected, 1 warning (0.03 sec)mysql> show tables;<br/>+------------------------------+| Tables_in_test_version |<br/>+------------------------------+| mytable |<br/>+------------------------------+</span>
Executed in strict 모드
관련 권장사항: php에서 폭발을 사용하여 문자열을 분할할 때 초보자가 쉽게 간과하는 문제에 대한 설명 위 내용은 mysql 엄격 모드 엄격 모드에 대한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!<span style="color: rgb(0, 0, 0);">mysql> CREATE TABLE `mytable` ( -> `id` int(11) NOT NULL AUTO_INCREMENT, -> `name` varchar(20) NOT NULL, -> `content` text NOT NULL default '', -> PRIMARY KEY (`id`) -> ) ENGINE=InnoDB DEFAULT CHARSET=utf8;<br/>ERROR 1101 (42000): BLOB/TEXT column 'content' can't have a default value</span>
이 기사에서는 mysql 엄격 모드 엄격 모드에 대해 설명하고 있나요? 더 많은 관련 권장 사항을 보려면 PHP 중국어 웹사이트를 참고하세요.