勉強したことのメモ

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で全文検索(フルテキストインデックス)を使用する方法

普段利用しているサイトに検索用のテキストボックスがあり、そこに何らかのワードを入 ...

MySQLでユーザー作成時にエラーが発生

SSHからrootアカウントでMySQLにログインし、ユーザーを作成しようとする ...

MySQLで特定の値を加算しつつNULL値の場合は0にする方法

いくつかのコードに対して投票を行い、その合計値をスコアとして出したい。ただ、投票 ...

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

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

MySQLでユニークキーをはる

MySQLでseqとcodeみたいなものをあわせて ユニークキーをはりたかった。 ...