小さな整数の違いをしっかり理解!smallintとtinyintの使い分けガイド

  • このエントリーをはてなブックマークに追加
小さな整数の違いをしっかり理解!smallintとtinyintの使い分けガイド
この記事を書いた人

小林聡美

名前:小林 聡美(こばやし さとみ) ニックネーム:さと・さとみん 年齢:25歳 性別:女性 職業:季節・暮らし系ブログを運営するブロガー/たまにライター業も受注 居住地:東京都杉並区・阿佐ヶ谷の1Kアパート(築15年・駅徒歩7分) 出身地:長野県松本市(自然と山に囲まれた町で育つ) 身長:158cm 血液型:A型 誕生日:1999年5月12日 趣味: ・カフェで執筆&読書(特にエッセイと季節の暮らし本) ・季節の写真を撮ること(桜・紅葉・初雪など) ・和菓子&お茶めぐり ・街歩きと神社巡り ・レトロ雑貨収集 ・Netflixで癒し系ドラマ鑑賞 性格:落ち着いていると言われるが、心の中は好奇心旺盛。丁寧でコツコツ型、感性豊か。慎重派だけどやると決めたことはとことん追求するタイプ。ちょっと天然で方向音痴。ひとり時間が好きだが、人の話を聞くのも得意。 1日のタイムスケジュール(平日): 時間 行動 6:30 起床。白湯を飲んでストレッチ、ベランダから天気をチェック 7:00 朝ごはん兼SNSチェック(Instagram・Xに季節の写真を投稿することも) 8:00 自宅のデスクでブログ作成・リサーチ開始 10:30 近所のカフェに移動して作業(記事執筆・写真整理) 12:30 昼食。カフェかコンビニおにぎり+味噌汁 13:00 午後の執筆タイム。主に記事の構成づくりや装飾、アイキャッチ作成など 16:00 夕方の散歩・写真撮影(神社や商店街。季節の風景探し) 17:30 帰宅して軽めの家事(洗濯・夕飯準備) 18:30 晩ごはん&YouTube or Netflixでリラックス 20:00 投稿記事の最終チェック・予約投稿設定 21:30 読書や日記タイム(今日の出来事や感じたことをメモ) 23:00 就寝前のストレッチ&アロマ。23:30に就寝


小見出し1: smallintとtinyintの基本を知ろう

まず、smallintとtinyintは整数を扱うデータ型です。データベースの世界では、数を数えるときに使う容量が違います。

tinyintは1バイト、smallintは2バイトと覚えるとよいでしょう

この容量の違いにより、扱える数の範囲が変わります。

具体的には、署名ありの場合の範囲はおおむね次のとおりです。

tinyintは-128127、smallintは-3276832767です。

これらはDBによって少し違うことがあります。

たとえば、unsignedをつけると範囲は正の数だけになります。

このような違いを知っておくと、データを詰め込みすぎてオーバーフローする事故を避けられます。

次に、実際の使い道を考えます。

小さな範囲のカウントやフラグ、年齢のような小規模な値にはtinyintを使うケースが多いです。

ただしDBによって「unsigned」の扱いが異なるので注意が必要です。

以下の表は、よく使われるDBの範囲の目安を比較したものです。

実務ではDBの仕様書を必ず確認してください。

<table>データ型範囲(署名あり/未署名)TINYINT署名あり: -128〜127
未署名: 0〜255SMALLINT署名あり: -32768〜32767
未署名: 0〜65535table>

小見出し2: 実務での使い分けのコツと落とし穴

実務では、何をどこに格納するかをまず考えます。

データの正確さとメモリのバランスの両方を見て判断します。

たとえば、フラグ用の値ならtinyint(1)を使うケースが多いです。

ただしSQL Serverではtinyintは0〜255の範囲で、署名/unsignedの区別はありません。

一方、年齢や入社年数のように将来大きくなる可能性のある数値にはsmallintを選ぶと安全です。

ここで大切なのは、上限を見積もることとDBの仕様を統一することです。

仕様がバラバラだと、別のDBに移すときにデータが収まらなくなるかもしれません

また、booleanのような意味を持つ値を格納したいときは、tinyintを使う代わりに専用のboolean型を使えるDBもありますが、MySQLでは実際にはtinyintを流用することが多いです。

この辺りの挙動はDBのドキュメントを確認して確かめましょう。

  • 用途別の目安:小さな値にはtinyint、将来の成長を見越してsmallintを選ぶのが無難です。
  • 署名と未署名の違い:signedは負の数も扱えるが、unsignedは0以上のみで、格納サイズの使い方が変わります。
  • 実務の落とし穴:DBごとに仕様が違うので、仕様書の確認を徹底しましょう。
ピックアップ解説

ある日のデータベース勉強会。新人のAさんがunsignedは何ですかと質問してきました。先輩の私は unsigned は「符号なし」という意味で、0以上の値だけを扱えると説明します。tinyintの上限を127や255に広げられるのはunsignedを使う選択肢のおかげです。Aさんは「なるほど、範囲を広げる工夫なんだね」と理解を深め、私たちは例としてカウント用やIDの使い分けについて雑談します。


の人気記事

会所桝と集水桝の違いを徹底解説|用途と設置場所をわかりやすく
732viws
ラフタークレーンとラフテレーンクレーンの違いを徹底解説!現場で役立つ選び方と使い分けのコツ
506viws
c-2とc-1の違いを完全解説!下地調整材の選び方と使い分け
469viws
意見聴収と意見聴取の違いを完全マスター:場面別の使い分けと注意点を中学生にもわかる言葉で解説
454viws
dBとdB(A)の違いを徹底解説!音のデシベルを正しく使い分ける入門ガイド
450viws
ゲート弁とスルース弁の違いをわかりやすく解説!現場で使い分けるためのポイント
435viws
COAと試験成績書の違いを徹底解説!どちらをいつ確認すべき?
432viws
圧着端子と圧縮端子の違いを徹底解説|使い分けのコツと選び方を中学生にもわかる解説
423viws
ベニヤとラワンの違いを徹底比較!初心者にもわかる素材選びガイド
422viws
A4サイズとB5サイズの違いを徹底解説!用途別の選び方と実務で役立つ使い分けガイド
396viws
凍結防止剤と融雪剤の違いを徹底解説:名前が似ても役割が違う理由を中学生にもわかりやすく
389viws
消石灰と生石灰の違いを完全解説!誰でもわかる使い分けと安全ポイント
388viws
フランジとルーズフランジの違いを徹底解説|基本から使い分けのコツまで
350viws
ハット型と鋼矢板の違いを徹底解説!現場で使える選び方ガイド
347viws
中心線測量と縦断測量の違いを徹底解説!地図づくりの基本を押さえる
347viws
SDSとTDSの違いを徹底解説!役立つ使い分けと実務ポイントを中学生にもわかる解説
346viws
ジップロックとジップロップの違いを徹底解説!正しい呼び名と使い方を知ろう
341viws
ドラグショベルとパワーショベルの違いを徹底解説!現場での使い分けと選び方のコツ
339viws
CPKとPPKの違いを完全解説!意味と用途を中学生にも分かりやすく比較
324viws
小型移動式クレーンと移動式クレーンの違いを徹底解説|現場で役立つ選び方と使い方
318viws

新着記事

の関連記事