ADO.NETについて教えて欲しいことがあります。
1つのシステムで、1つのメインのデータベースへ接続するとき、
ADO.NETを使用して接続しています。
これに、サブのシステムで使用している別な接続(ADO.NET)がある、
という場合においてお話します。
メインのデータベース検索において、サブのシステムで使用している
テーブルのデータに基づいてJoin(結合)した結果を得たいのですが、
これは可能なのでしょうか?
いろいろ接続間の検索について調べていたのですが、これといった情報が無く
途方に暮れていました。
最悪はアプリケーションで、と思いますが、
汎用性を考えるとアプリケーションでの実現は限界がある、
と思いました。
何か、よい方法などございましたら、ご教授お願いします。
No.4ベストアンサー
- 回答日時:
お世話になります。
> どうすれば設定できるのか、なんですが、Primaryキーの話は
> 見つかるんですけど、インデックスについての情報がなかなか見つかりません(>_<)。
DataTable メンバを見たのですが、
http://msdn2.microsoft.com/ja-jp/library/system. …
Constraints や PrimaryKey のインターフェースは
ありますが、インデックスについては無さそうですね。
全件を DataSet に読み込むのではなく、
ある程度対象を絞ってから DataSet に読み込む方法
がパフォーマンス面での心配が軽減されるかもしれません。
アドバイスありがとうございます。
やはりDataSetを、メモリ上の一時データベースとして扱うのは
限界があるようですね。
何故、DataSetに読み込んで使うかと言えば、
WebService経由でデータベース検索を行なうために、
通信回数を限りなく1回に近づけるためなのでした。
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.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.1
- 回答日時:
もしかしたら、ご希望に沿わないかもしれませんが、メインシステムのほうで検索するときに、あらかじめ規則によって命名されたビューを作って、そのビューとサブシステムの方でJoinしてみてはどうでしょうか?
メインの方はビューを作って、その結果で選択結果を得るということになります。
回答ありがとうございます。
メインシステムとサブシステムとで、DBが異なる場合なんですが、
ビューを作ることはできませんよね?
2種類のADO.NETのオブジェクト(例えばOracleとMySQL)があり、
例えば、MySQLのほうにユーザー情報があって、
Oracleのほうに部署マスタなどの情報がある場合で、
ユーザー情報を画面に出すときなど、マスタの情報を得たいとき
なんですが、MySQLのほうのデータにSelect文を発行しますが、
マスタを取得するには、OracleのほうにもSelect文を発行しなければ
いけません。ADO.NETの接続間でJoinができ、クエリーを事実上1回で
行なえればいいのですが、そんなことが可能なのか!?
と半信半疑で情報を求めていました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
select文の戻り値を変数に格納...
-
ASP.NET:複数結合テーブルのデ...
-
ACCESSテーブルを RecordSet以...
-
【ACCESS】リレーションを組ん...
-
SQL文(テーブル項目名が特殊文...
-
ExcelVBAを使って、値...
-
テキストボックスのvalueとtext...
-
VB.NETで DataRow()を利用して...
-
[エクセル]連続する指定範囲か...
-
i=cells(Rows.Count, 1)とi=cel...
-
表にフィルターをかけ、絞った...
-
ListView 項目の選択/選択解除...
-
【Excel VBA】指定行以降をクリ...
-
TODAY()で設定したセルの日付...
-
VBA:小数点以下の数字を取得で...
-
【Excel】指定したセルの名前で...
-
array関数で格納した配列の型を...
-
特定のセルが空白だったら、そ...
-
Accessのクエリで、replace関数...
-
count(*)で取得した値をJAVAの...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
select文の戻り値を変数に格納...
-
SQL文(テーブル項目名が特殊文...
-
【ACCESS】リレーションを組ん...
-
access コンボボックス初期表示...
-
DBの読み込み順について
-
ACCESSテーブルを RecordSet以...
-
外部キーのリレーションが設定...
-
ASP.NET:複数結合テーブルのデ...
-
テーブルというグローバル変数
-
VBとACCESSを接続したい
-
accessのフォームを使ってテー...
-
ASPとAccessとの接続について
-
DataGridViewで編集した内容を...
-
Perlで変数内の日本語が文字コ...
-
HTML&CSS Javascriptによる動...
-
単純なjoin句の必要性
-
Windows formアプリで データグ...
-
異なるデータベースでのSELECT ...
-
ASPNETDB.MDFのスキーマについて
-
[ADO.NET]接続間の検索について
おすすめ情報