Golang は高速で効率的なプログラミング言語です。他の言語に比べて学習曲線が平坦であり、並行性のパフォーマンスが非常に優れているため、現在、ますます多くのプログラマーがこの言語に注目しています。そのため、Web 開発で人気があります。バックエンド開発の分野で幅広い用途に使用できます。
Web アプリケーションを開発する場合、データベースのクエリ操作は避けられず、その中でも条件付きクエリは非常に重要です。この記事では、Golang を使用して条件付きクエリを実行する方法を紹介します。
ステップ 1: データベースに接続する
条件付きクエリを実行する前に、まずデータベースに接続する必要があります。 Golang には、Gorm、sqlx、go-sql-driver など、選択できるオープン ソース データベース ドライバーが多数あります。この記事では、条件付きクエリを実行する方法を示す例として Gorm を使用します。
Gorm を使用してデータベースに接続するには、次の手順が必要です:
コマンド ラインを使用してインストールできます:
go get -u github.com/jinzhu/gorm
Gorm パッケージをインポートした後、データベース ドライバー パッケージをインポートする必要がありますたとえば、Mysql ドライバー パッケージをインポートします。
import (
"github.com/jinzhu/gorm" _ "github.com/jinzhu/gorm/dialects/mysql"
)
接続時データベースに接続するには、データベース接続情報を提供する必要があります。例:
db, err := gorm.Open("mysql", "user:password@tcp(dbhost:port)/dbname?charset =utf8&parseTime=True&loc=Local")
このステートメントは DB を作成します。オブジェクトはデータベースに接続されます。これには、ユーザー名、パスワード、データベース ホスト、ポート番号などの情報のほか、次のような情報が含まれます。文字セット、時刻形式、タイムゾーン。
ステップ 2: クエリ条件を構築する
データベースに接続した後、クエリ条件を構築する必要があります。クエリ条件は重要な部分であり、データベースからどのようなデータを取得するかを指定します。 Gorm はチェーン メソッドを使用してクエリ条件を構築し、Where()、Not()、Or()、And() などの一般的に使用されるメソッドをいくつか提供します。
Where() メソッドは、指定された条件を満たすレコードをフィルタリングするために使用されます。例:
db.Where( "age > ; ?", 18)
このステートメントは、年齢が 18 を超えるレコードを返します。
Not() メソッドは、指定された条件を満たさないレコードをフィルタリングするために使用されます。例:
db .Not("age > ?", 18)
このステートメントは、年齢が 18 以下のレコードを返します。
Or() メソッドと And() メソッドは、次のような複雑なクエリ条件を構築するために使用されます。
db.Where("age > ?", 18).Or("weight > ?", 60)このステートメントは、年齢が 18 より大きいか、重みがそれより大きいレコードを返します。 60以上。 db.Where("age > ?", 18).And("name = ?", "Tom")このステートメントは、年齢が 18 より大きい人々を返します。彼の名前はトム・レコードです。 上記のメソッドに加えて、Gorm はデータベースからデータを取得するために使用できる Find()、First()、Last() などの他のメソッドも提供します。 ステップ 3: クエリを実行するクエリ条件を作成したら、クエリ ステートメントを実行してデータベースからデータを取得する必要があります。 Gorm のクエリ メソッドも非常に多様で、クエリ結果が期待どおりであることを確認するための Find()、First()、Last()、Count() などのメソッドが提供されています。 db.Where("age > ?", 18).Find(&users)
db.Where("age > ?", 18).First(&user)
db.Last(&user)
db.Table("users").Where("age > ?", 18).Count(&count)
以上がgolangの条件付きクエリの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。