質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.46%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

Q&A

解決済

1回答

5525閲覧

C#でMariaDB(Mysql)を使ってSelect文を使って値を取得する方法について

aikawajun

総合スコア14

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

0グッド

0クリップ

投稿2021/12/02 05:39

現在、MariaDBを自分のPCにインストールして、Visual Studioを使ってC#でDBにOPEN、CLOSEやINSERT、SELECT等行いたいと思いソースを書いております。

参考できそうなサイトからMySql.Dataのパッケージをインストールして、まずはOPEN、CLOSEすることは出来ました。
また、テーブルの追加やデータの追加や削除もMariaDBに付いてきたHeidiSQLを使って確認出来ました。

ただ、SELECT文だけどうしてもエラーになってしまい、詰まっております。
以下一部抜粋

command.CommandText = "SELECT name FROM person;"; // SQLの実行 MySqlDataAdapter adapter = new MySqlDataAdapter(command.CommandText, _db); DataTable table = new DataTable(); adapter.Fill(table);

トライキャッチしたエラーとしては、「System.Collections.Generic.KeyNotFoundException」が出ておりました。
ただ、以前別のWebサーバーでSSHを使って作業していた際はうまく出来ていたため、何が原因かが探しているのですが、さっぱりわかっておりません。

もし、同じような点で分かる方がいらっしゃいましたら教えて頂きたいです。

以下、開発環境
OS:Windows10
VisualStudioのバージョン:Community 2019 Ver 16.9.1
プロジェクトの種類:WindowsForms
フレームワークの種類:.NET Framework 4.8

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

コードがメチャクチャです。基本以下のような形になります。

using System; using System.Data; using MySql.Data.MySqlClient; namespace ConsoleAppMySQL { class Program { static void Main(string[] args) { string query = "SELECT Code, Name, Continent FROM country"; string connStr = "server=localhost;user id=root;password=********;database=world"; // DataReader を使った接続型 using (var connection = new MySqlConnection(connStr)) { using (var command = new MySqlCommand(query, connection)) { connection.Open(); using (var reader = command.ExecuteReader()) { while (reader.Read()) { var code = reader[0].ToString(); var name = reader[1].ToString(); var continent = reader[2].ToString(); Console.WriteLine($"Code: {code}, Name: {name}, Continent: {continent}"); } } } } // DataTable を使った非接続型 var table = new DataTable(); using (var connection = new MySqlConnection(connStr)) { using (var command = new MySqlCommand(query, connection)) { var adapter = new MySqlDataAdapter(); adapter.SelectCommand = command; adapter.Fill(table); } } foreach (DataRow row in table.Rows) { Console.WriteLine($"Code: {row.Field<string>("code")}, Name: {row.Field<string>("name")}, Continent: {row.Field<string>("continent")}"); } } } }

投稿2021/12/02 06:18

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aikawajun

2021/12/02 08:38

ご回答ありがとうございます。 頂いたソースで確認したところ、トライキャッチしていなかったため、 using (var reader = command.ExecuteReader()) の箇所で System.NotSupportedException: 'Character set 'utf8mb3' is not supported by .Net Framework.' とエラーが出ていました。 テーブル作成時はテキスト列に指定をしていなかったため、「utf8mb3_general_ci」になっておりました。 もし分かればでよいのですが、標準的な文字指定は何を選んだ方が良いでしょうか。 よろしくお願いいたします。
aikawajun

2021/12/02 09:33

一応、和訳してutf8mb3が使えないことが分かり、utf8mb3をググって代わりのものが何か探していましたが、エラー文ではググっておりませんでした。 教えて頂いたURLの方を一度確認してみたいと思います。 ありがとうございます。
aikawajun

2021/12/03 05:53

MariaDB側の文字設定を一切していなかったことが原因のようでした。 下記サイトを参考にしたところ、 https://lilia-study.com/mariadb/mariadb-utf8mb4/ 自分で作ったソースでも問題なくSelect文が通るようになりました。 MariaDBをインストールして使うのは初めてだったため、色々学べました。 ありがとうございます。
退会済みユーザー

退会済みユーザー

2021/12/03 07:14

質問者さんが使った MariaDB の char-set がデフォルトで utf8mb3 で、それを C# アプリで ADO.NET + Oracle 製プロバイダ (Connector/NET) を利用して使おうとしたら、その Connector/NET が utf8mb3 をサポートしてなかったということだったのでしょうか。 Oracle 製の MySQL, MySQL for Visual Studio, Connector/NET を一式 Oracle のインストーラーを使ってインストールして使った方が、相性の問題に悩まなくて済むと思うのですが・・・ MySQL をインストールしました(その 3) http://surferonwww.info/BlogEngine/post/2020/04/20/installation-of-mysql-on-new-desktop-pc.aspx
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.46%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問