カテゴリ: Go言語 更新日: 2026/01/25

Go言語のクエリ実行を完全解説!Query・QueryRowの基本と使い分けを初心者向けにやさしく理解

Go言語のクエリ実行(Query・QueryRow)の基本と応用例
Go言語のクエリ実行(Query・QueryRow)の基本と応用例

先生と生徒の会話形式で理解しよう

生徒

「Go言語でデータベースからデータを取り出したいんですが、どうやって読むんですか?」

先生

「Go言語では、QueryQueryRowという仕組みを使って、データベースに質問して結果を受け取ります。」

生徒

「2つもあると、どっちを使えばいいのか分からなくなりそうです……」

先生

「大丈夫です。役割はとてもシンプルなので、例えを使いながら順番に説明していきます。」

1. Go言語でのクエリ実行とは何か

1. Go言語でのクエリ実行とは何か
1. Go言語でのクエリ実行とは何か

Go言語でのクエリ実行とは、データベースに対して「この条件に合うデータをください」とお願いする操作のことです。 このお願いの文章がSQLと呼ばれる命令文で、データベースとの会話に使われます。 Go言語では、このSQLを使ってデータを読み取るために、QueryQueryRowという2つの方法が用意されています。 プログラミング未経験の方は、クエリ実行を「引き出しの中から必要な書類を探して取り出す作業」だと考えると分かりやすいです。

2. QueryとQueryRowの違いをイメージで理解

2. QueryとQueryRowの違いをイメージで理解
2. QueryとQueryRowの違いをイメージで理解

QueryとQueryRowの違いは、取り出したいデータの量にあります。 Queryは「条件に合うものを全部ください」というお願いで、複数のデータをまとめて取得します。 一方、QueryRowは「この条件に合うものを1つだけください」というお願いです。 例えるなら、Queryは箱いっぱいのリンゴを受け取る方法で、QueryRowは1個だけリンゴを受け取る方法です。 この違いを理解するだけで、使い分けは一気に簡単になります。

3. Queryの基本的な使い方

3. Queryの基本的な使い方
3. Queryの基本的な使い方

Queryは、複数行のデータを取得したいときに使います。 例えば、ユーザー一覧や商品リストのように、何件あるか分からないデータを扱う場合です。 Queryを実行すると、結果がそのままでは使えない形で返ってくるため、1行ずつ順番に読み取る必要があります。 この読み取り作業は、ページをめくりながらノートを読むイメージに近いです。


rows, err := db.Query("SELECT id, name FROM users")
if err != nil {
    // エラー処理
}
defer rows.Close()

for rows.Next() {
    var id int
    var name string
    rows.Scan(&id, &name)
}

4. rows.NextとScanの意味

4. rows.NextとScanの意味
4. rows.NextとScanの意味

rows.Nextは、「次のデータがありますか?」と確認するための仕組みです。 データがある間はtrueになり、すべて読み終えるとfalseになります。 Scanは、取り出したデータをGo言語の変数に入れる作業です。 封筒に入った書類を取り出して、机の上に並べるようなイメージを持つと理解しやすくなります。 この2つはQueryを使うときに必ず登場する重要なポイントです。

5. QueryRowの基本的な使い方

5. QueryRowの基本的な使い方
5. QueryRowの基本的な使い方

QueryRowは、1行だけ結果を取得したいときに使います。 例えば、IDを指定してユーザー情報を1人分だけ取得するような場合です。 Queryと違い、ループ処理は不要で、そのままScanを呼び出せます。 必要な情報が1つだと分かっている場面では、QueryRowを使うとコードがとてもスッキリします。


var name string
err := db.QueryRow("SELECT name FROM users WHERE id = ?", 1).Scan(&name)
if err != nil {
    // エラー処理
}

6. QueryRowでエラーが出る理由

6. QueryRowでエラーが出る理由
6. QueryRowでエラーが出る理由

QueryRowでは、結果が見つからなかった場合にエラーが返されます。 これは「条件に合うデータが存在しません」という合図です。 プログラムが壊れたわけではなく、データが無いことを正しく伝えてくれています。 初心者の方はエラーを見ると不安になりますが、これは正常な動作の一部なので安心してください。

7. QueryとQueryRowの使い分けまとめ

7. QueryとQueryRowの使い分けまとめ
7. QueryとQueryRowの使い分けまとめ

複数の行を扱うならQuery、1行だけならQueryRowというルールを覚えておくと迷いません。 どちらもGo言語でデータベース操作を行う上で欠かせない基本機能です。 クエリ実行の考え方を理解すると、データベースとのやり取りが一気に身近になります。 難しそうに見えても、実際は「聞く」「受け取る」というシンプルな流れです。

Go言語を基礎からスッキリ学びたい人や、 文法だけでなく「実用的な使い方」まで押さえたい人には、 定番の入門書がこちらです。

基礎からわかるGo言語をAmazonで見る

※ Amazon広告リンク

8. 初心者がつまずきやすいポイント

8. 初心者がつまずきやすいポイント
8. 初心者がつまずきやすいポイント

よくある失敗として、Queryを使ったあとにCloseを忘れてしまうことがあります。 また、Scanの順番とSQLの列の順番が合っていないと、思わぬ値が入ってしまいます。 これらは慣れるまで誰でも通る道なので、落ち着いて一つずつ確認することが大切です。 基本を丁寧に積み重ねることで、安定したGo言語のデータベース処理が書けるようになります。

関連セミナーのご案内

【超入門】ゼロから始めるGo言語プログラミング:最速で「動くアプリ」を作るマンツーマン指導

「プログラミングの仕組み」が根本からわかる。Go言語でバックエンド開発の第一歩を。

本講座を受講することで、単なる文法の暗記ではなく、「プログラムがコンピュータの中でどう動いているか」という本質的な理解につながります。シンプルながら強力なGo言語(Golang)を通じて、現代のバックエンドエンジニアに求められる基礎体力を最短距離で身につけます。

具体的な開発内容と環境

【つくるもの】
ターミナル(黒い画面)上で動作する「対話型計算プログラム」や、データを整理して表示する「ミニ・ツール」をゼロから作成します。自分の書いたコードが形になる感動を体験してください。

【開発環境】
プロの現場でシェアNo.1のVisual Studio Code (VS Code)を使用します。インストールから日本語化、Go言語用の拡張機能設定まで、現場基準の環境を一緒に構築します。

この60分で得られる3つの理解

1. 環境構築の完全な理解

「なぜ動くのか」という設定の仕組みを理解し、今後の独学で詰まらない土台を作ります。

2. Go言語の基本構造(変数・型)

データの種類やメモリの概念など、他言語にも通じるプログラミングの本質を学びます。

3. 読みやすいコードの書き方

ただ動くだけでなく、誰が見ても分かりやすい「綺麗なコード」を書くための考え方を伝授します。

※本講座は、将来的にバックエンドエンジニアクラウドインフラに興味がある未経験者のためのエントリー講座です。マンツーマン形式により、あなたの理解度に合わせて進行します。

セミナー画像

初めてのGo言語を一緒に学びましょう!

関連記事:
カテゴリの一覧へ
新着記事
New1
Kotlin
Kotlinで依存関係管理を始めよう!Gradle/Mavenの基本設定と導入手順
New2
Kotlin
Kotlinのreturnラベルを完全解説!初心者でもわかるクロスラインreturnの基本
New3
Kotlin
Kotlinでファイルアクセスを安全に管理する方法を徹底解説 初心者でも理解できるファイル読み書きとセキュリティ対策
New4
Go言語
Go言語の構造体を使った設計パターン集(DTO・VOなど)
人気記事
No.1
Java&Spring記事人気No1
Kotlin
Gradleファイル(build.gradle.kts)の書き方と役割をやさしく解説!Kotlin初心者向け完全ガイド
No.2
Java&Spring記事人気No2
Swift
Swift開発環境の構築方法を徹底解説!Xcode・Windows・Linux対応
No.3
Java&Spring記事人気No3
Kotlin
Android Studioのインストール手順と初期設定を初心者向けに完全解説!
No.4
Java&Spring記事人気No4
Swift
Swift Playgroundの使い方を完全解説!初心者に最適な学習環境の始め方
No.5
Java&Spring記事人気No5
Kotlin
KotlinのRoomでコルーチン対応!suspend関数とFlowの使い方をやさしく解説
No.6
Java&Spring記事人気No6
Kotlin
Kotlinの文字列の部分取得!substring・take・dropの基本
No.7
Java&Spring記事人気No7
Kotlin
Kotlinの演算子一覧と使い方!算術・比較・論理演算子の基本を解説
No.8
Java&Spring記事人気No8
Kotlin
Kotlinのインストール方法まとめ!Windows・Mac・Linux別にステップ解説