테스트 사이트 - 개발 중인 베타 버전입니다

mysql 5.0.x 공백문자인식

· 17년 전 · 3200 · 2

서버 셋팅상에서 MYSQL 5.0.X버전에서는 sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"

이구문이 추가되있어야 공백문자를 인식한다는군요^^

[이 게시물은 관리자님에 의해 2011-10-31 17:27:00 MySQL에서 이동 됨]

댓글 작성

댓글을 작성하시려면 로그인이 필요합니다.

로그인하기

댓글 2개

17년 전
공백문자 인식이 어디에서 문제가 되나요??? 궁금해서요^^
5.0 이상에서 기본적인 세팅값은 sql-mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"인데 여기서 STRICT_TRANS_TABLES 값이 있으면 테이블 필드의 정의에 따라 값이 정확이 입력이 되어야 insert가 됩니다. 예를 들면 no integer default ''이라고 정의했을 때 integer 값은 공백문자를 가질 수 없으므로 정의 자체도 문제거니와 공백문자 값을 insert 하려고 하면 에러가 발생합니다. 그래서 아래 버젼과 호환을 이루기 위해서는 STRICT_TRANS_TABLES 를 sql-mode에서 제거해 주어야 합니다. 관리자님의 설명은 그래서 잘못되었구요. 원래 의미는 트랜잭션 테이블에 값을 입력할 수 없다면 쿼리 구문 수행을 금지한다는 뜻이구요. 대부분의 php보드 생성 및 사용을 보면 위의 예처럼 올바른 정의와 올바른 값을 insert하지 않는 경우가 많기 때문에 만일 앞으로 mysql에서 sql-mode를 기본값으로 정의해서 사용하는 호트팅 서버를 쓰게 될 경우에는 소스를 수정해야할 부분들이 많게 됩니다.

NO_AUTO_CREATE_USER는 자동 사용자 생성 금지로 grant로 생성하던 것을 막겠다는 뜻이구요,

NO_ENGINE_SUBSTITUTION는 엔진 대체 금지로 create 이나 alter 명령시 엔진을 바꾸는 일이 있는데 그것을 막습니다.

참고: http://dev.mysql.com/doc/refman/5.0/en/server-sql-mode.html

게시글 목록

번호 제목
29416
13230
13227
13226
13225
13224
25107
13219
13218
13216
13211
13210
29415
13204
13202
29411
13199
13196
13192
13191
13189
13186
29408
13185
13183
13178
13173
13166
13165
13163
13162
13157
13153
13149
13144
13142
13141
13140
13138
13137
13136
25102
13135
13132
13131
13130
13128
13125
13117
13116
13114
13113
13109
13106
13105
13103
13102
13099
13096
13091
29404
13090
13087
29400
13085
13082
29398
13081
13080
13077
25097
13076
13075
13072
13071
29397
13069
13068
13063
13060
25092
25091
25090
13056
13055
13054
29396
13045
13042
13026
13022
13017
13013
13008
13002
12998
25083
12997
29394
29392