現在、過去にAccess で作成しましたシステムをASP.Net にて作り変えております。
GridView のデータソースとして 動的なWhere文を必要としていることから
以前、SQLDataSourceよりもObjectDataSourceに変更したほうが良いとのアドバイスをいただき、赤間本と呼ばれる構築技法の書籍も購入しまして日夜勉強しているASP.Net初心者の者であります。
こちらの本の第10章からが動的Where文を紹介している部分だと思うのですが、なかなか難解で頭に入ってきません。
【こちらでやった事】
DataSetを作成し、基本SQLを作り、TableAdapter を作成しました。
【まずわからない事】
例えば Where句が全て埋まっている場合のSQLが下記のものだとします。
SELECT * FROM test WHRE A = @para1 AND B = @para2 AND C = @para3
動的SQL文を作成したいので
SELECT * FROM test WHRE A = @para1 だったり
SELECT * FROM test WHRE B = @para2 だったり
SELECT * FROM test WHRE C = @para3 だったり
SELECT * FROM test WHRE A = @para1 AND B = @para2 だったり
SELECT * FROM test WHRE B = @para2 AND C = @para3 だったり
SELECT * FROM test WHRE A = @para1 AND C = @para3 だったり
SELECT * FROM test WHRE A = @para1 AND B = @para2 AND C = @para3 だったりと
全部で7通りあるわけです。
書籍には、クエリを追加するようにと記述されているのですが、
これら7通りを全て記述して
クエリの条件にあったモノを選択し、実行させ
GridView にバインドさせるのでしょうか?
もしそうだとすると パラメーターが仮に10個あったとしたら
すごい数のクエリを追加していくことになるのかなと思い、
まずは、どういう概念で登録していくのかをお教えいただければと存じます。
今まで、動的SQL の場合は、パラメーターが空白、NULLの場合にはSQL文に含めない形で
SQL文を作成し、レコードソースにしていたのでTableAdapter を作成して
どのような形で動的クエリを実行させるのかがまったくつかめていない状況でございます。
なんとかこの壁を突破し前へ進めればと思っております。
よろしくお願い申し上げます。
No.1ベストアンサー
- 回答日時:
TableAdapterてのは、データの入れ物であるDataTableと、アクセス手段の合成体です。
以前からあった、DataAdapterを、複数のアクセスメソッドを持てるようにしてクラス化しています。
で、そのDataAdapterてのは、Connectionとか、OleDBオブジェクトをラップしています。
なので、掘っていけばどんどん下層のレイヤが見えてくるので、どうにでも変更できます。
コース料理を頼んでおいて、一品料理を変更したり、追加するような感じ?
具体的には、TableAdapterはパーシャルクラスなので、自分の好きなメソッドを追加したり、ウィザードで作ったアクセスメソッドを引っ張り出して、SQLを変更したりできます。
http://d.hatena.ne.jp/JHashimoto/20110703/130969 …
リンク例にあるように、各メソッドにアクセス属性をつけておくと、ObjectDataSourceのメソッド選択ウィザードにHitするので捗るらしいのですが、自分は手動でメソッド指定しています。
shockatz様、大変お世話になっております。
最新の質問までいろいろとご指導ありがとうございます。
ObjectDataSource とDBの接続方法、動的SQL文の設定、
そのほか、いろいろな接続、変更などの方法の仕方が未熟ゆえ
わからない次第でございます。
まだグリッドビューの動的SQLの変更方法など、まだわたくしには早かったかなと質問の回答を見させていただき思って次第でございます。
まずは ご紹介いただいた、赤間本を読破、熟読し、グリッドビュー、リストビューの選定など、改めてご質問させて下さいませ。
その際には初心者にもわかるご回答お待ち申し上げております。
ありがとうございました。
No.2
- 回答日時:
リンク記事はDBが何とpostgresやった。
(まあいちおうTableADapterの拡張方法は同じなので)
こちらの記事の方が明快。ObjectDataSourceまわりも書いてある。
http://www.atmarkit.co.jp/fdotnet/vs2005db/vs200 …
この回答への補足
shockatzさん 大変お世話になっております。
ご紹介いただいた 赤間本こと、構築技法の書籍は非常に読みやすく、今まで不明な部分だった事が解き明かされるようで、本当に購入してよかった書籍だと思いました。この場をお借りして御礼申し上げます。
なんとなくだんだんわかってきたのですが、確証がつかめない感じなので、補足にて改めて、私が考えている概要があっているかどうかご指摘いただければと存じます。
ご指摘いただいたページにあるパーシャル・クラスの例題に関してなのですが
(1) App_CodeフォルダにDataSet用のクラスを作成する部分なのですが、
例題にある引数
Public Function GetBooksDataSet(ByVal publish As String)
この部分の publish これは何か決められた文字列なのでしょうか?
もしかして、この例題の関数自体が独自に作成されているのでこの引数もユーザーが勝手に決めて良いものなのでしょうか?
(publish とは ユーザーが勝手に決めた引数? もしかしてこの辺りも自由自在?)
(2) 同じ例題にある
comm.CommandText = "SELECT * FROM books"
この部分なのですが、もしかして comm.CommandText = SQL文
この部分ににユーザーが自由自在にSQL文を設定できるのですか?
自由自在にパーシャル・クラスで設定できるというのはこの事なのでしょうか?
(3) グリットビューにGetBooksDataSetをバインドさせてから
実際に、グリッドビューのデータを変更させるためには
例えば、ボタンオブジェクトから パーシャル・クラスの GetBooksDataSetを呼び出せば
GetBooksDataSetが実行されてグリットビューのデータが更新されると考えてよろしいのでしょうか?
うまくご説明できませんが、上記3つの問題が解決できれば大きく前に進めるかと思います。
何卒ご教授いただけますようよろしくお願い申し上げます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
エラーの意味を
-
コマンドプロンプト実行後に画...
-
final修飾子を使っているのに、...
-
タブコントロールの問題 (VB)
-
引数は省略できません。とのコ...
-
エクセルVBAにおけるON TIMEメ...
-
Excel VBA でExcelを終了したい...
-
DataGridViewでセルクリックイ...
-
アクセスVBA 時間を止める
-
EXCEL VBAの構造体検索について
-
Refreshメソッドの使い方
-
mainメソッドのthrows節で設定...
-
Range クラスのAutoFitプロパテ...
-
FEM解析の読み方は?
-
ODBCでMoveNextがうまく動作し...
-
VB.NET デリゲートへのコールバ...
-
c#でC言語のstrtokに...
-
Windowsプログラムから音を出す...
-
Strutsで「setterメソッドが見...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
DataGridViewでセルクリックイ...
-
コマンドプロンプト実行後に画...
-
Labelコントロールに数字を代入...
-
エクセルVBAにおけるON TIMEメ...
-
JSPで<SELECT>の中にDBから持っ...
-
ウィンドウを最前面にできません
-
final修飾子を使っているのに、...
-
【sendkeysメソッドが動かずに...
-
mainメソッドのthrows節で設定...
-
onClickで関数呼出し後に、結果...
-
Application.Wait の参照設定
-
VBA コピーが出来ません…!
-
VBPをダブルクリックするとたま...
-
javascriptからjavaを呼び出したい
-
Refreshメソッドの使い方
-
配列のメソッド
-
エクセルのマクロでプリンタを...
-
boolean型のフィールドとゲッタ...
-
C#で右からnカラム目に文字を挿...
おすすめ情報