DbProviderFactoryを使用することにより、データプロバイダに依存しない実装が可能。で、備忘録
使用可能なProvider一覧を取得DbProviderFactories.GetFactoryClasses();
戻り値はDataTable型なので、DataGridViewを使えば簡単に内容を確認することができる。
ApplicationでDataProviderを追加したい場合は、app.configに設定することで追加可能。 例えば、PostgreSQLの場合は、↓の様に設定。
<system.data> <DbProviderFactories> <add name="Npgsql Data Provider" invariant="Npgsql" description=".Net Framework Data Provider for PostgreSQL" type="Npgsql.NpgsqlFactory, Npgsql, Version=2.0.8.0, Culture=neutral, PublicKeyToken=5d8b90d52f46fda7" /> </DbProviderFactories> </system.data>
app.configよりConnectionStringを取得してDbProviderFactoryを作成
ConnectionStringSettings css = ConfigurationManager.ConnectionStrings["MyConnection"]; DbProviderFactory factory = DbProviderFactories.GetFactory(css.ProviderName);
ConnectionStringSettingsよりProviderNameを取得し、DbProviderを作成
あとは、factory.CreateXXXXX()で作成し放題!
0 件のコメント:
コメントを投稿