ホームページ  >  記事  >  データベース  >  C# で MySQL データベースに接続するにはどうすればよいですか?エラーレポートの例外と追加、削除、変更、クエリの詳細な説明

C# で MySQL データベースに接続するにはどうすればよいですか?エラーレポートの例外と追加、削除、変更、クエリの詳細な説明

php是最好的语言
php是最好的语言オリジナル
2018-08-03 16:25:404688ブラウズ

この記事では、C# による MySQL データベースへの接続について説明します。詳細なケースは、接続エラーが発生した場合に MySqlConnection で返されます。

2 つの変数: Message と Number です。

  1. mysql-connector-net-8.0.12 をダウンロードしてインストールし、リファレンスに Mysql.Data を追加します。

  2. using MySql.Data.MySqlClient; と記述する必要があります。図に示すようにC# で MySQL データベースに接続するにはどうすればよいですか?エラーレポートの例外と追加、削除、変更、クエリの詳細な説明

はMySQLデータベースがインストールされていることを前提としています。デフォルトではC:Program Files (x86)MySQLにインストールされています。Connector.NETのインストールを選択することをお勧めします。インストール中の 8.0.12。これには、MySQL と C# がリンクされたダイナミック リンク ライブラリが含まれます。

ヘルプドキュメント C:Program Files (x86)MySQLConnector.NET 8.0.12DocumentationConnectorNET.chm がこの記事を書くための主な基礎です。このうちユーザーガイドでは、プログラミングがダイナミックリンクライブラリの8つのクラスの紹介、チュートリアルがケースコードとなっています。

データベースに接続して操作する本質は、データベースが提供するダイナミックリンクライブラリMySql.Data.dllを使用して操作することです。 MySql.Data.dll は、次の 8 つのクラスを提供します。

  • MySqlConnection: MySQL サーバー データベースに接続します。

  • MySqlCommand: SQL ステートメントを実行します。

  • MySqlDataReader: SQL ステートメントの実行結果が含まれており、結果から行を読み取るメソッドを提供します。

  • MySqlTransaction: MySQL データベース内の SQL トランザクションを表します。

  • MySqlException: MySQL がエラーを報告すると例外が返されます。

  • MySqlCommandBuilder: DataSet に加えられた変更を関連する MySQL データベースと調整するために使用される単一テーブルのコマンドを自動的に生成します。

  • MySqlDataAdapter: 使用される一連のデータ コマンドとデータベース接続を表します。データセットを入力し、MySQL データベースを更新します。

  • MySqlHelper: プロバイダーとの連携を容易にするヘルパー クラスです。

1. ダイナミック リンク ライブラリ ファイルを追加します

: ビジュアルStudio、プロジェクト内 (右クリック) - NuGet パッケージの管理 (N) 次に、[参照] で MySql.Data を検索してインストールします。

方法 2: データベース MySQL をインストールするときに、Connector.NET 6.9 のインストールを選択し、C:Program Files (x86)MySQLConnector.NET 8.0.12Assemblies の v4.0 または v4.5 に MySql.Data.dll を追加します。プロジェクトへの参照。 v4.0 および v4.5 は、特定の Visual Studio プロジェクトの [プロパティ]-[アプリケーション]-[ターゲット フレームワーク] の .NET Framework バージョン番号に対応します。

2. 接続を確立する (MySqlConnection クラス)

= =

3. 例外をキャッチする (MySqlException クラス)

接続エラーが発生すると、MySqlConnection は 2 つの変数を含む MySqlException を返します。

メッセージ: 現在の例外を説明するメッセージ。

数値: MySQL エラー番号 (0: サーバーに接続できません。1045: ユーザー名および/またはパスワードが無効です。)

catch (MySqlException ex)
{    switch (ex.Number)
    {        case 0:
        Console.WriteLine("Cannot connect to server.  Contact administrator");        break;    case 1045:
        Console.WriteLine("Invalid username/password, please try again");        break;
    }
}

4. , コードの削除、確認、変更 (MySqlCommand クラス、MySqlDataReader クラス)

ExecuteReader - データベースのクエリに使用されます。クエリ結果は返される MySqlDataReader オブジェクトです。MySqlDataReader には SQL ステートメントの実行結果が含まれており、結果から行を読み取るメソッドを提供します。

ExecuteNonQuery - データの挿入、更新、削除に使用されます。

ExecuteScalar — データのクエリに使用すると、クエリ結果セットの最初の行と列の値が返されます。つまり、値が 1 つだけ返されます。 (1) クエリ

a. クエリ条件は固定です

string sql= "select * from user";
MySqlCommand cmd = new MySqlCommand(sql,conn);
MySqlDataReader reader =cmd.ExecuteReader();//执行ExecuteReader()返回一个MySqlDataReader对象while (reader.Read())//初始索引是-1,执行读取下一行数据,返回值是bool{    //Console.WriteLine(reader[0].ToString() + reader[1].ToString() + reader[2].ToString());    //Console.WriteLine(reader.GetInt32(0)+reader.GetString(1)+reader.GetString(2));
    Console.WriteLine(reader.GetInt32("userid") + reader.GetString("username") + reader.GetString("password"));//"userid"是数据库对应的列名,推荐这种方式}

b. クエリは値を返す必要があります

//string sql = "select * from user where username='"+username+"' and password='"+password+"'"; //我们自己按照查询条件去组拼string sql = "select * from user where username=@para1 and password=@para2";//在sql语句中定义parameter,然后再给parameter赋值MySqlCommand cmd = new MySqlCommand(sql, conn);
cmd.Parameters.AddWithValue("para1", username);
cmd.Parameters.AddWithValue("para2", password);

MySqlDataReader reader = cmd.ExecuteReader();if (reader.Read())//如果用户名和密码正确则能查询到一条语句,即读取下一行返回true{    return true;
}

(2) 挿入、削除、変更

string sql = "insert into user(username,password,registerdate) values('啊宽','123','"+DateTime.Now+"')";//string sql = "delete from user where userid='9'";//string sql = "update user set username='啊哈',password='123' where userid='8'";MySqlCommand cmd = new MySqlCommand(sql,conn);int result =cmd.ExecuteNonQuery();//3.执行插入、删除、更改语句。执行成功返回受影响的数据的行数,返回1可做true判断。执行失败不返回任何数据,报错,下面代码都不执行

 5.事务(MySqlTransaction类)

String connetStr = "server=127.0.0.1;user=root;password=root;database=minecraftdb;";
MySqlConnection conn = new MySqlConnection(connetStr);
conn.Open();//必须打开通道之后才能开始事务MySqlTransaction transaction = conn.BeginTransaction();//事务必须在try外面赋值不然catch里的transaction会报错:未赋值Console.WriteLine("已经建立连接");try{    string date = DateTime.Now.Year + "-" + DateTime.Now.Month + "-" + DateTime.Now.Day;    string sql1= "insert into user(username,password,registerdate) values('啊宽','123','" + date + "')";
    MySqlCommand cmd1 = new MySqlCommand(sql1,conn);
    cmd1.ExecuteNonQuery();    string sql2 = "insert into user(username,password,registerdate) values('啊宽','123','" + date + "')";
    MySqlCommand cmd2 = new MySqlCommand(sql2, conn);
    cmd2.ExecuteNonQuery();
}catch (MySqlException ex)
{
    Console.WriteLine(ex.Message);
    transaction.Rollback();//事务ExecuteNonQuery()执行失败报错,username被设置unique
    conn.Close();
}finally{    if (conn.State != ConnectionState.Closed)
    {
        transaction.Commit();//事务要么回滚要么提交,即Rollback()与Commit()只能执行一个
        conn.Close();
    }
}

  结语:连接数据库、操作数据库,本质是利用数据库提供的动态链接库MySql.Data.dll进行操作。动态链接库中的8个类上面常用操作只用到了类1-5,类6-8 的相关操作未涉及, 大家可以去看帮助文档C:\Program Files (x86)\MySQL\Connector.NET 8.0.12\Documentation\ConnectorNET.chm学习。

相关文章:

C# Using MySQL

mysql Connector C/C++ 多线程封装

以上がC# で MySQL データベースに接続するにはどうすればよいですか?エラーレポートの例外と追加、削除、変更、クエリの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。