.NETでODBCを使用してデータベースに接続しSQLを実行するサンプル †.NETのOdbcConnection クラスなどを利用し、データベースにODBC接続するサンプルコードになります。 参考サイト †
関連記事 †使用したデータベースとODBCドライバ †
動作確認環境 †
ビルド(C#),コンパイル(VB)時の注意 †ODBCドライバに対する、対象プラットフォームが適切でない場合は、以下の例外が発生ます。 C# †Visual Basic(VB) †ODBC接続をしてSELECT, INSERT, UPDATE をするサンプルコード †以下に C#, Visual Basic(VB) によるデータベース接続とデータベース操作のサンプルコードを記します。 サンプルコード内で CREATE TABLE, DROP TABLEも行っています。 C# ODBCサンプルコード †using System; using System.Data; using System.Data.Odbc; namespace OdbcSampleCS { class Program { static void Main(string[] args) { string DSN = @"OdbcSampleDSN"; string createTable = @"create table t1 (c1 int, c2 varchar(100))"; string dropTable = @"drop table t1"; string selectSQL = @"select * from t1"; string insertSQL = @"insert into t1 values(?,?)"; string updateSQL = @"update t1 set c2 = ? where c1 = ?"; OdbcConnectionStringBuilder odbcConBuilder = new OdbcConnectionStringBuilder(); odbcConBuilder.Dsn = DSN; using (OdbcConnection odbcCon = new OdbcConnection(odbcConBuilder.ToString())) { OdbcCommand cmd = new OdbcCommand(); cmd.Connection = odbcCon; try { odbcCon.Open(); OdbcParameter param1 = new OdbcParameter(); OdbcParameter param2 = new OdbcParameter(); // CREATE TABLE cmd.CommandText = createTable; cmd.ExecuteNonQuery(); // INSERT cmd.CommandText = insertSQL; param1.DbType = DbType.Int32; param1.Value = 10; cmd.Parameters.Add(param1); param2.DbType = DbType.String; param2.Value = "Windows10"; cmd.Parameters.Add(param2); cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); // SELECT cmd.CommandText = selectSQL; using (OdbcDataReader odr = cmd.ExecuteReader()) { while (odr.Read()) { Console.WriteLine("{0},{1}", odr["c1"], odr["c2"]); } } // UPDATE cmd.CommandText = updateSQL; param1.DbType = DbType.String; param1.Value = "ウインドウズ10"; cmd.Parameters.Add(param1); param2.DbType = DbType.Int32; param2.Value = 10; cmd.Parameters.Add(param2); cmd.ExecuteNonQuery(); cmd.Parameters.Clear(); // SELECT cmd.CommandText = selectSQL; using (OdbcDataReader odr = cmd.ExecuteReader()) { while (odr.Read()) { Console.WriteLine("{0},{1}", odr["c1"], odr["c2"]); } } // DROP TABLE cmd.CommandText = dropTable; cmd.ExecuteNonQuery(); } catch (Exception ex) { Console.WriteLine(ex.Message); } } } } } Visual Basic(VB) ODBCサンプルコード †Imports System Imports System.Data Imports System.Data.Odbc Module Module1 Sub Main() Dim DSN As String = "OdbcSampleDSN" Dim createTable As String = "create table t1 (c1 int, c2 varchar(100))" Dim dropTable As String = "drop table t1" Dim selectSQL As String = "select * from t1" Dim insertSQL As String = "insert into t1 values(?,?)" Dim updateSQL As String = "update t1 set c2 = ? where c1 = ?" Dim odbcConBuilder As OdbcConnectionStringBuilder = New OdbcConnectionStringBuilder() odbcConBuilder.Dsn = DSN Using odbcCon As OdbcConnection = New OdbcConnection(odbcConBuilder.ToString()) Dim cmd As OdbcCommand = New OdbcCommand With { .Connection = odbcCon } Try odbcCon.Open() Dim param1 As OdbcParameter = New OdbcParameter() Dim param2 As OdbcParameter = New OdbcParameter() 'CREATE TABLE cmd.CommandText = createTable cmd.ExecuteNonQuery() 'INSERT cmd.CommandText = insertSQL param1.DbType = DbType.Int32 param1.Value = 10 cmd.Parameters.Add(param1) param2.DbType = DbType.String param2.Value = "Windows10" cmd.Parameters.Add(param2) cmd.ExecuteNonQuery() cmd.Parameters.Clear() 'SELECT cmd.CommandText = selectSQL Using odr As OdbcDataReader = cmd.ExecuteReader() While odr.Read() Console.WriteLine("{0},{1}", odr("c1"), odr("c2")) End While End Using 'UPDATE cmd.CommandText = updateSQL param1.DbType = DbType.String param1.Value = "ウインドウズ10" cmd.Parameters.Add(param1) param2.DbType = DbType.Int32 param2.Value = 10 cmd.Parameters.Add(param2) cmd.ExecuteNonQuery() cmd.Parameters.Clear() 'SELECT cmd.CommandText = selectSQL Using odr As OdbcDataReader = cmd.ExecuteReader() While odr.Read() Console.WriteLine("{0},{1}", odr("c1"), odr("c2")) End While End Using 'DROP TABLE cmd.CommandText = dropTable cmd.ExecuteNonQuery() Catch ex As Exception Console.WriteLine(ex.Message) End Try End Using End Sub End Module 実行結果 †上記サンプルコードを実行したときの出力になります。 以上、.NETでODBC接続しデータベース操作を行うサンプルコードでした。 |