Laravel은 MySQL5.1에서 실행할 때 오류가 발생합니다. 오류는 다음과 같습니다.
<code>SQLSTATE[HY000]: General error: 1366 Incorrect integer value: ''1'' for column 'status' at row 1 (SQL: insert into `cases` (`case_name`, `status`, `updated_at`, `created_at`) values ('fdsafdsadsa', '1', 1474504956, 1474504956)) </code>
하지만 제가 작성한 PDO는 테스트 실행에는 문제가 없습니다
<code>try { $sth = $db->prepare('insert into cases(case_name,status,updated_at,created_at) values (?,?,?,?)'); $sth->bindValue(1, '我也是中文', PDO::PARAM_STR); $sth->bindValue(2, '1', PDO::PARAM_INT); $sth->bindValue(3, time(), PDO::PARAM_INT); $sth->bindValue(4, time(), PDO::PARAM_INT); $sth->execute(); } catch (\Exception $e) { echo $e->getMessage(); }</code>
데이터 테이블 구조:
저도 온라인에서 확인해보니 SQL_MODE를 변경하고 변경했는데 계속 오류가 뜹니다
쉘 필터링 추가로 인해 발생한 큰따옴표 문제가 해결되었습니다
Laravel은 MySQL5.1에서 실행할 때 오류가 발생합니다. 오류는 다음과 같습니다.
<code>SQLSTATE[HY000]: General error: 1366 Incorrect integer value: ''1'' for column 'status' at row 1 (SQL: insert into `cases` (`case_name`, `status`, `updated_at`, `created_at`) values ('fdsafdsadsa', '1', 1474504956, 1474504956)) </code>
하지만 제가 작성한 PDO는 테스트 실행에는 문제가 없습니다
<code>try { $sth = $db->prepare('insert into cases(case_name,status,updated_at,created_at) values (?,?,?,?)'); $sth->bindValue(1, '我也是中文', PDO::PARAM_STR); $sth->bindValue(2, '1', PDO::PARAM_INT); $sth->bindValue(3, time(), PDO::PARAM_INT); $sth->bindValue(4, time(), PDO::PARAM_INT); $sth->execute(); } catch (\Exception $e) { echo $e->getMessage(); }</code>
데이터 테이블 구조:
저도 온라인에서 확인해보니 SQL_MODE를 변경하고 변경했는데 계속 오류가 뜹니다
쉘 필터링 추가로 인해 발생한 큰따옴표 문제가 해결되었습니다