Go言語のNULL値の扱い方を完全解説!sql.NullStringなどの型を初心者向けにやさしく説明
生徒
「Go言語でデータベースを使っていたら、NULLっていう値でエラーが出ました。NULLって何ですか?」
先生
「NULLは『値が入っていない』という意味を持つ特別な状態です。Go言語では、そのままでは扱えないので専用の型を使います。」
生徒
「専用の型って難しそうです……」
先生
「大丈夫です。身近な例えを使いながら、sql.NullStringなどの型を順番に見ていきましょう。」
1. NULL値とは何か?
Go言語でデータベース操作を始めると、必ず出会うのがNULL値です。NULLとは「空文字」や「ゼロ」とは違い、「そもそも値が存在しない」状態を表します。
たとえば、名簿に「電話番号」の欄があるとします。まだ電話番号を登録していない人の場合、その欄は空白になります。この「未記入」の状態が、データベースではNULLとして扱われます。
Go言語のstring型やint型は、必ず何らかの値を持つ仕組みになっています。そのため、NULLを直接入れようとするとエラーが発生します。
2. Go言語でNULLが問題になる理由
Go言語は安全性を重視したプログラミング言語です。そのため「値がある前提」で変数を扱います。一方、データベースは「値がない状態」も自然に扱います。
この考え方の違いが原因で、Go言語とデータベースをつなぐときにNULLの問題が起こります。特に初心者の方は、なぜエラーが出るのか分からず戸惑いやすいポイントです。
3. sql.NullStringとは?
Go言語には、database/sqlパッケージの中にNULLを安全に扱うための型が用意されています。その代表例がsql.NullStringです。
sql.NullStringは「文字列の値」と「有効かどうか」をセットで管理する構造になっています。値が存在するときは有効、NULLのときは無効、という状態をはっきり区別できます。
これは「箱の中にメモが入っているかどうか」を確認するイメージに近いです。箱が空ならNULL、メモが入っていれば文字列、という考え方です。
4. sql.NullStringの基本的な使い方
type User struct {
Name sql.NullString
}
このように構造体でsql.NullStringを使うことで、データベースのNULLを安全に受け取れます。
if user.Name.Valid {
fmt.Println(user.Name.String)
} else {
fmt.Println("名前は未登録です")
}
Validがtrueなら値あり、falseならNULLです。この確認を行うことで、予期しないエラーを防げます。
5. sql.NullInt64やsql.NullBoolもある
文字列だけでなく、数値や真偽値にもNULL対応の型があります。たとえばsql.NullInt64やsql.NullBoolです。
考え方はすべて同じで、「値」と「有効かどうか」をセットで管理します。一度理解できれば、他の型も迷わず使えるようになります。
6. NULL対応型を使うメリット
sql.NullStringなどの型を使う最大のメリットは、安全性です。NULLを見落としたまま処理を進めると、実行時エラーにつながります。
Go言語では「コンパイル時に気づける設計」を大切にしています。NULL対応型は、その思想に合った仕組みだと言えます。
7. 初心者がつまずきやすいポイント
初心者の方がよく混乱するのは、「空文字」と「NULL」の違いです。空文字は「値はあるが中身がない」、NULLは「値そのものが存在しない」状態です。
この違いを意識するだけで、Go言語のデータベース操作はぐっと分かりやすくなります。