勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLで「Uncaught mysqli_sql_exception: BIGINT ~~」エラーの対応方法

  MySQL データベース

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 データベース

  関連記事

MySQLでREGEXPについて

SQL文にREGEXPというのを見てこれ何? となったのでメモ。 ■参考サイト ...

MySQLで一連の処理を関数のように実行できるストアドプロシージャの設定と利用方法

MySQL関連のサイトを見ていた際にストアドプロシージャが云々というページがあっ ...

お名前.comのレンタルサーバ(SDサーバ)にMySQLデータのインポートする方法

お名前.comのレンタルサーバにそこそこ大きいサイズのMySQLデータを移行した ...

MySQLでカラム内容によって条件分岐させたい場合の対応方法

MySQLでカラムの内容によって条件を分岐させたかった。またPHPで処理するので ...

htmlspecialcharsを通してMySQLに格納したものを元に戻して出力

MySQLにHTMLタグを入れたくない場合にhtmlspecialcharsを使 ...