ADO.NETについて教えて欲しいことがあります。
1つのシステムで、1つのメインのデータベースへ接続するとき、
ADO.NETを使用して接続しています。
これに、サブのシステムで使用している別な接続(ADO.NET)がある、
という場合においてお話します。
メインのデータベース検索において、サブのシステムで使用している
テーブルのデータに基づいてJoin(結合)した結果を得たいのですが、
これは可能なのでしょうか?
いろいろ接続間の検索について調べていたのですが、これといった情報が無く
途方に暮れていました。
最悪はアプリケーションで、と思いますが、
汎用性を考えるとアプリケーションでの実現は限界がある、
と思いました。
何か、よい方法などございましたら、ご教授お願いします。
No.1
- 回答日時:
もしかしたら、ご希望に沿わないかもしれませんが、メインシステムのほうで検索するときに、あらかじめ規則によって命名されたビューを作って、そのビューとサブシステムの方でJoinしてみてはどうでしょうか?
メインの方はビューを作って、その結果で選択結果を得るということになります。
回答ありがとうございます。
メインシステムとサブシステムとで、DBが異なる場合なんですが、
ビューを作ることはできませんよね?
2種類のADO.NETのオブジェクト(例えばOracleとMySQL)があり、
例えば、MySQLのほうにユーザー情報があって、
Oracleのほうに部署マスタなどの情報がある場合で、
ユーザー情報を画面に出すときなど、マスタの情報を得たいとき
なんですが、MySQLのほうのデータにSelect文を発行しますが、
マスタを取得するには、OracleのほうにもSelect文を発行しなければ
いけません。ADO.NETの接続間でJoinができ、クエリーを事実上1回で
行なえればいいのですが、そんなことが可能なのか!?
と半信半疑で情報を求めていました。
No.2
- 回答日時:
Oracleは、使ったことが無いので分かりませんが、
リンクって出来ませんか。
SQLServerで、他のサーバーのリンク
SELECT * FROM [他のサーバー名].データベース名.dbo.テーブル名 tbl
で、他のサーバーのテーブルのビューを作成
そして、メインのサーバーと結合して結果を得る。
もし、リンク先がTEXTファイルの時(c:\A.txt)
SELECT *
FROM OPENDATASOURCE('Microsoft.Jet.OLEDB.4.0',
'Data Source="C:\";User Id=Admin;Password=;Extended properties=Text' )... [ a#txt
]
テキストファイルでもリンクできますので多分
Oracleでも出来るのでは、
回答ありがとうございます。
なるほど、そういうテクニックがあるんですね。
でも、OracleはOracleクライアントがインストールされていないと
SQLを発行できません。今、作っているアプリは、IIS経由で実行し、
サーバーにOracleクライアントを置いているんです。
そのサーバーが複数台(大規模ですよね^^;)あるので、
サーバーとサーバーの関係はアプリケーションしか判断できないんです。
そうしたとき、個々に接続することになりますから、
コネクション間でJOINできないものか、と思っていたのでした。
貴重な意見、ありがとうございました。
No.3
- 回答日時:
お世話になります。
王道だと DataSet で、DataRelation を使って
DataSet 内の DataTable 同士の関連をつくってやる
方法になると思われます。
あんまりオススメはしませんが、
Oracle と MySQL のテーブルを
ODBC を介してどっちも
Access のリンクテーブルとして扱ってしまい、
.NET 側からはその Access しかみないようにする、
という少々乱暴な手段もあるにはあります。
参考URL:http://msdn2.microsoft.com/ja-jp/library/system. …
アドバイスありがとうございます。
やはりアプリケーションでの制御、ということになりそうですね。
クライアントにDB接続のドライバは入れないようにしてます。
ですから、ODBCで云々、というのは今回は意に沿わない、
ということになってしまいます。でも、そういうテクニックがあるんだ、
ということで、アイデアとして受け止めておきます。
DataRelationの方法は、別な質問で教わり技術は理解したんですが、
データ量が多い場合に、どこまでパフォーマンスが出るのか、
というのが今、一番悩んでいるポイントでした。
検索キーになりそうな項目に、インデックスを設定したいのですが、
どうすれば設定できるのか、なんですが、Primaryキーの話は
見つかるんですけど、インデックスについての情報がなかなか見つかりません(>_<)。
No.4ベストアンサー
- 回答日時:
お世話になります。
> どうすれば設定できるのか、なんですが、Primaryキーの話は
> 見つかるんですけど、インデックスについての情報がなかなか見つかりません(>_<)。
DataTable メンバを見たのですが、
http://msdn2.microsoft.com/ja-jp/library/system. …
Constraints や PrimaryKey のインターフェースは
ありますが、インデックスについては無さそうですね。
全件を DataSet に読み込むのではなく、
ある程度対象を絞ってから DataSet に読み込む方法
がパフォーマンス面での心配が軽減されるかもしれません。
アドバイスありがとうございます。
やはりDataSetを、メモリ上の一時データベースとして扱うのは
限界があるようですね。
何故、DataSetに読み込んで使うかと言えば、
WebService経由でデータベース検索を行なうために、
通信回数を限りなく1回に近づけるためなのでした。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- Wi-Fi・無線LAN PCWi-Fiの設定方法がわからなくて困っています。 4 2022/12/28 18:30
- カスタマイズ(車) (続き)初めてカーナビの取付にチャンレジします。アドバイスください。 3 2022/12/10 15:13
- カスタマイズ(車) いわゆる「テレビキャンセラー」について・・・・・ 7 2022/11/01 20:57
- ドライブ・ストレージ pcの外付けハードディスクの共有方法 4 2022/11/28 05:17
- iPhone(アイフォーン) iPhoneを親として、iPadを子として、テザリングする場合、、、、 1 2022/04/17 20:18
- モニター・ディスプレイ 現在、使用しているPCに、モニター3台が繋がらない。 4 2023/03/09 20:06
- ドライブ・ストレージ ネットワークHDD(NAS)について教えて下さい。 11 2023/03/08 11:15
- その他(パソコン・スマホ・電化製品) 現在、Q-SL2を使用しています。Q-H1を接続しようとすると本体ソフトウェア確認中にエラーが発生し 1 2023/03/04 23:14
- ハッキング・フィッシング詐欺 JS/Packed.Agent.N が検出されたサイトにアクセスするとどうなる? 4 2022/08/12 18:28
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Windows formアプリで データグ...
-
DBの読み込み順について
-
特定のセルが空白だったら、そ...
-
ExcelVBAを使って、値...
-
VBAでセルをクリックする回...
-
ハッシュテーブル(連想配列)が...
-
Excelのセルの色指定をVBAから...
-
VBからEXCELのセルの値を取得す...
-
Excelで指定した日付から過去の...
-
Accessのクエリで、replace関数...
-
特定の文字を条件に行挿入とそ...
-
【Excel】指定したセルの名前で...
-
ExcelのINDEXとMATCH関数でスピ...
-
Sub 要具ライフ() ActiveSheet....
-
VBAでActiveDirectoryのユーザ...
-
Excelで勤怠管理をしたいです。...
-
【VBA】配列に数式を仕込む方法...
-
PysimpleGUIでデータベースを作る
-
VB.NETで DataRow()を利用して...
-
VBA listBoxについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SQL文(テーブル項目名が特殊文...
-
select文の戻り値を変数に格納...
-
【ACCESS】リレーションを組ん...
-
ACCESSテーブルを RecordSet以...
-
VBとACCESSを接続したい
-
テーブルというグローバル変数
-
DBの読み込み順について
-
access コンボボックス初期表示...
-
accessのフォームを使ってテー...
-
DataGridViewで編集した内容を...
-
外部キーのリレーションが設定...
-
HTML&CSS Javascriptによる動...
-
ASP(VBScript)で自動連番
-
Perlで変数内の日本語が文字コ...
-
EF(コードファースト)のコン...
-
ASP.NET:複数結合テーブルのデ...
-
フラッシュの画像を合わせるパ...
-
教えてアクセス2007!「在...
-
テーブルへのデータ投入について。
-
ExcelVBAを使って、値...
おすすめ情報