現代のソフトウェア エンジニアリングでは、効率的で信頼性の高いサーバー アプリケーションを構築するために必要なスキルの需要が高まっています。その中でもGo言語を使ってリレーショナルデータベースを呼び出すことは必須の基礎となります。この記事では、Go 言語の標準パッケージを使用して、MySQL データのクエリと挿入を行います。
database/sql パッケージが含まれており、このパッケージには標準 SQL データベース インターフェイスが実装されており、MySQL、PostgreSQL、SQLite などの他の便利で一般的な SQL データベースと対話できます。
go get -u github.com/go-sql-driver/mysql を使用できます。
SQL.DB 接続を通じて行われる必要があるためです。ドライバーの目的は、
database/sql の関数にインターフェイス規約を実装することです。
db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/dbname") if err != nil { log.Fatal(err) }
db.Query()、
db.QueryRow()## を使用できます。 #anddb.Exec()
関数は、MySQL データベース内のデータをクエリおよび操作します。
この関数は複数のレコードをクエリするために使用され、*sql.Rows
オブジェクトを返します。 db.QueryRow()
この関数は、単一レコードをクエリするために使用され、resultset
と同様の *sql.Row
オブジェクトを返しますが、返されるのはレコードの最初の行。通常、単一の一意のレコードをクエリするために使用されます。 db.Exec()
この関数は、INSERT、UPDATE、DELETE などの非クエリ SQL ステートメントを実行するために使用され、sql.Result
オブジェクトを返します。 この例では、
関数を使用してすべてのレコードをクエリします。シンプルなカウンターを使用してレコード数をカウントし、データの各行をコンソールに出力します。 <pre class="brush:php;toolbar:false">rows, err := db.Query("SELECT id, name FROM users")
if err != nil {
log.Fatal(err)
}
defer rows.Close()
count := 0
for rows.Next() {
var id int
var name string
if err := rows.Scan(&id, &name); err != nil {
log.Fatal(err)
}
fmt.Printf("id=%d, name=%s\n", id, name)
count++
}
if err := rows.Err(); err != nil {
log.Fatal(err)
}
fmt.Printf("Found %d users\n", count)</pre>
関数は、データを取得した後に呼び出して、*sql.Rows
に関連付けられたデータベース リソースを解放する必要があります。同時に、コード内では rows.Next()
関数が使用されており、処理できる行がまだあるかどうかを示すブール値を返します。さらに、この例では rows.Scan()
関数を使用して、各行レコードの値を、この例で定義されている id
変数と name
変数にコピーします。たとえば、 、各値をコンソールに出力します。
db.Exec() 関数に渡すと、MySQL で SQL ステートメントとして実行されます。
result, err := db.Exec("INSERT INTO users(name, email) VALUES('John Doe', 'johndoe@gmail.com')") if err != nil { log.Fatal(err) } rowsAffected, err := result.RowsAffected() if err != nil { log.Fatal(err) } fmt.Printf("Inserted %d rows into users table\n", rowsAffected)
result.RowsAffected() を使用して結果セット内の影響を受ける行の数を取得し、この値を使用して更新されたデータの数をコンソールに出力できます。 まとめ
db.Exec() 関数を使用して MySQL データベースにデータを挿入する方法も学びました。これらの概念は、Go で効率的で信頼性の高いサーバー アプリケーションを構築する上で重要な部分であり、最新のソフトウェア エンジニアリングにおいて不可欠なスキルです。
以上がgolangでmysqlデータを操作する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。