###前提・実現したいこと
Laravel Framework 5.4.36
10.1.25-MariaDB
NOT NULL、デフォルト値0のtimestamp型カラムへinsert時にエラーが発生します。
対応策を探しています。
(PHPは経験ありますが、Laravelを使用するのは初めてです。)
###発生している問題・エラーメッセージ
(画面に表示された内容を無修正でそのまま転記します。)
QueryException
SQLSTATE[22007]: Invalid datetime format: 1978 Incorrect default value '0000-00-00 00:00:00' for column 'updated_at' (SQL: insert into servers (kind, address, db_name, note) values(1, 127.0.0.1, server1, test))
----------------------
in Connection.php (line 647)
----------------------
(以下stacktraceが続きますが多くなるため省略)
###該当のソースコード
(class Server extends Model内のコードです。)
PHP
1$query = 'insert into servers (kind, address, db_name, note) values(?, ?, ?, ?)'; 2// $kind, $address, $db_name, $noteには上記エラーメッセージ中のSQLにある値が格納されています 3$param = [$kind, $address, $db_name, $note]; 4$result = DB::insert($query, $param);
###試したこと
MariaDB(MySQL)ではsql_modeによりtimestampに0が挿入可能か不可能かを設定できることを知り、確認したところ、0を挿入できる設定でした。実際、エラーメッセージのSQLをコピーし、valuesの各値を「'」で囲ってからphpmyadminで実行すると正常に挿入できました。
timestampに値の範囲があることを知り、「servers」テーブルのupdated_atカラムの定義を調べました。
NOT NULLでデフォルト値0でしたので、ためしにデフォルト値を問題ない数値(1999-12-31 23:59:59)にしたところ、エラーなく挿入できました。
Laravelが原因か確認するため、timestampのデフォルト値を0に戻し、以下のコードを実行したところ正常にinsertできました。
$dsn = "mysql:dbname=dev_db;host=127.0.0.1;charset=utf8mb4"; $username = "root"; $password = ""; $pdo = new \PDO($dsn, $username, $password); $stmt = $pdo->exec("insert into servers (kind, address, db_name, note) values('1', '127.0.0.1', 'server1', 'test')");
ここまで確認するとLaravelが原因なのはほぼ間違いないと思いますが、対応策が分かりません。
恐らく、LaravelのDB::insertメソッド内で正常なtimestamp値の範囲であるかどうかをチェックしているのではないかと思いましたが、Laravelのソースコードが追えず、原因と対応策が分からない状態です。
質問の修正依頼に「SHOW CREATE TABLE servers;」の結果を、ということでしたので追記します。
+---------+------------------------------------------------------------
| Table | Create Table
+---------+------------------------------------------------------------
| servers | CREATE TABLE servers
(
id
int(11) NOT NULL AUTO_INCREMENT,
kind
varchar(3) CHARACTER SET utf8 NOT NULL,
address
varchar(15) CHARACTER SET utf8 NOT NULL,
db_name
varchar(255) CHARACTER SET utf8 DEFAULT NULL,
note
text CHARACTER SET utf8,
delete_flg
tinyint(1) NOT NULL DEFAULT '0',
created_at
timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
updated_at
timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
updated_by
varchar(50) CHARACTER SET utf8 DEFAULT NULL,
PRIMARY KEY (id
)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=latin1 |
+---------+------------------------------------------------------------
1 row in set (0.00 sec)

回答1件
あなたの回答
tips
プレビュー