MySQLで「Uncaught mysqli_sql_exception: BIGINT ~~」エラーの対応方法
MySQLにて「Uncaught mysqli_sql_exception: BIGINT UNSIGNED value is out of range」というエラーが発生した。以下に原因をメモ。
原因
MySQLでUNSIGNED設定しているカラムを負の数にしようとしたためエラーとなった。以下テーブル構造、テーブル内容、実行しようとしたSQL文になる。
テーブル構造
mysql> SHOW COLUMNS FROM `test_table`; +-------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+--------------+------+-----+---------+----------------+ | id | int | NO | PRI | NULL | auto_increment | | count | int unsigned | NO | | NULL | | +-------+--------------+------+-----+---------+----------------+
データ内容
mysql> TABLE `test_table`; +----+-------+ | id | count | +----+-------+ | 1 | 0 | +----+-------+
実行しようとしたSQL文
UPDATE `test_table` SET `count` = `count` - 1 WHERE `id` = 1;
countカラムをデクリメントしようとしたところ負の数になりエラーが発生した。ちなみにUNSIGNED設定していない場合、エラーは発生せずcountカラムは「-1」になる。
対応方法
UNSIGNED設定しないようにするか、もしくは先にデータを取得しておき負の数になる場合はupdateしないようにする。
関連記事
-
-
MySQLで特定の値を加算しつつNULL値の場合は0にする方法
いくつかのコードに対して投票を行い、その合計値をスコアとして出したい。ただ、投票 ...
-
-
MySQLで全角半角を区別せずに検索する方法(collate utf8_unicode_ci)
あるシステムでMySQLの検索時に「WHERE test_column coll ...
-
-
エックスサーバーでMySQLのサイズに注意
エックスサーバーで自動更新のログをMySQLに保存するようなシステムを動かしてい ...
-
-
WordPressサイトのロードアベレージが高い際の対応方法
あるWordPressサイトのロードアベレージが先月ぐらいまでは通常0.5前後で ...
-
-
SortableJSを使ってデータの並べ替え&保存
あるシステムを拝見した際にtableタグ内に並んでいる項目をドラッグ&ド ...