この記事では、C# による MySQL データベースへの接続について説明します。詳細なケースは、接続エラーが発生した場合に MySqlConnection で返されます。
2 つの変数: Message と Number です。
mysql-connector-net-8.0.12 をダウンロードしてインストールし、リファレンスに Mysql.Data を追加します。
using MySql.Data.MySqlClient; と記述する必要があります。図に示すように
は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: プロバイダーとの連携を容易にするヘルパー クラスです。
: ビジュアル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 バージョン番号に対応します。
= =
接続エラーが発生すると、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; } }
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判断。执行失败不返回任何数据,报错,下面代码都不执行
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# で MySQL データベースに接続するにはどうすればよいですか?エラーレポートの例外と追加、削除、変更、クエリの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。