質問編集履歴
6
質問内容を別スレッドに分けるため追記を削除
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -30,42 +30,4 @@
|
|
|
30
30
|
' GetDataメソッドでデータを取得
|
|
31
31
|
Dim result As DataTable = adapter.GetData
|
|
32
32
|
コード
|
|
33
|
-
```
|
|
33
|
+
```
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
■追記(2021 2/20)
|
|
41
|
-
ご回答いただき、ありがとうございます。
|
|
42
|
-
|
|
43
|
-
また、情報が不足しており、申し訳ありません。
|
|
44
|
-
私が思っているより、だいぶ使い分けが難しそうですね・・。
|
|
45
|
-
|
|
46
|
-
> 質問者さんの例「単にデータベースからデータを取得して、その値によって処理を分岐」で、質問者さんがそのためのカスタムクラスを作るとして、そのカスタムクラスに DataTable を渡すのにどうするかによります。そこには組織の設計思想・ルール・質問者さんの好み等々が関係するはずです。
|
|
47
|
-
|
|
48
|
-
⇒カスタムクラスはどういった場合に作成を検討するものなのでしょうか。
|
|
49
|
-
|
|
50
|
-
> ただ、単純に DataTable が返ってくればいいということではなく、Fill メソッドの戻り値が欲しいとか、既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。
|
|
51
|
-
|
|
52
|
-
⇒「既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。」と記載していただきましたが、"追加"ということは、以下のように異なるSelect文をFillメソッド、FillByメソッドで実行した際に、DataTableを表す変数dtに、それぞれの実行結果が"追加"されるということでしょうか。
|
|
53
|
-
```VB
|
|
54
|
-
Dim adapter As New TestDataSetTableAdapters.BookTableAdapter
|
|
55
|
-
Dim dt As New TestDataSet.BookDataTable
|
|
56
|
-
|
|
57
|
-
' Fillメソッドでデータを取得
|
|
58
|
-
adapter.Fill(dt)
|
|
59
|
-
adapter.FillBy(dt)
|
|
60
|
-
```
|
|
61
|
-

|
|
62
|
-
試した限り、Fillメソッドの実行結果が、FillByメソッドの実行結果によって、上書きされて変数dtに格納されていたため、"追加"というのがどういう意味で使っていらっしゃるのかが分かりませんでした。
|
|
63
|
-
|
|
64
|
-
> そもそも「単にデータベースからデータを取得して、その値によって処理を分岐」という目的に型付 DataSet / DataTable + TableAdapter を使うのが適切かという話を考えるべきと思いますが、その話は今後の課題ということで・・・
|
|
65
|
-
|
|
66
|
-
⇒初歩的な質問となり、大変お恥ずかしいのですが、「型付 DataSet / DataTable」の型付とはどういうことでしょうか。手元にある書籍には、
|
|
67
|
-
「型付きデータセットとは、データセットに具体的なデータ構造(型)を定義し、特定のテーブル(データ)を格納するために用意された専用のデータセットと思っていただければ良いでしょう」
|
|
68
|
-
と書かれておりましたが、「データセットに具体的なデータ構造(型)を定義」という説明がよく分かりませんでした。
|
|
69
|
-
ここでいうデータ構造というのは、テーブル定義(カラムやカラムに格納する型など)を表したものという認識でよろしいのでしょうか。
|
|
70
|
-
|
|
71
|
-
質問事項が増えてしまい、申し訳ありません・・。
|
5
見やすさを改善
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -9,6 +9,11 @@
|
|
|
9
9
|
このFillメソッドとGetDataメソッドの使い分けはどのようにすれば良いのかが分かっておりません。
|
|
10
10
|
|
|
11
11
|
上記の2つのメソッドはどのように使い分けるべきなのでしょうか。
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
12
17
|
|
|
13
18
|
■追記(2021 2/19)
|
|
14
19
|
例えば、Webアプリを作成する際に、以下のようにxsdファイルにTableAdapterを定義したとします。
|
|
@@ -26,7 +31,12 @@
|
|
|
26
31
|
Dim result As DataTable = adapter.GetData
|
|
27
32
|
コード
|
|
28
33
|
```
|
|
29
|
-
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
|
|
30
40
|
■追記(2021 2/20)
|
|
31
41
|
ご回答いただき、ありがとうございます。
|
|
32
42
|
|
4
表示内容の改善
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -33,10 +33,12 @@
|
|
|
33
33
|
また、情報が不足しており、申し訳ありません。
|
|
34
34
|
私が思っているより、だいぶ使い分けが難しそうですね・・。
|
|
35
35
|
|
|
36
|
-
>質問者さんの例「単にデータベースからデータを取得して、その値によって処理を分岐」で、質問者さんがそのためのカスタムクラスを作るとして、そのカスタムクラスに DataTable を渡すのにどうするかによります。そこには組織の設計思想・ルール・質問者さんの好み等々が関係するはずです。
|
|
36
|
+
> 質問者さんの例「単にデータベースからデータを取得して、その値によって処理を分岐」で、質問者さんがそのためのカスタムクラスを作るとして、そのカスタムクラスに DataTable を渡すのにどうするかによります。そこには組織の設計思想・ルール・質問者さんの好み等々が関係するはずです。
|
|
37
|
+
|
|
37
38
|
⇒カスタムクラスはどういった場合に作成を検討するものなのでしょうか。
|
|
38
39
|
|
|
39
40
|
> ただ、単純に DataTable が返ってくればいいということではなく、Fill メソッドの戻り値が欲しいとか、既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。
|
|
41
|
+
|
|
40
42
|
⇒「既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。」と記載していただきましたが、"追加"ということは、以下のように異なるSelect文をFillメソッド、FillByメソッドで実行した際に、DataTableを表す変数dtに、それぞれの実行結果が"追加"されるということでしょうか。
|
|
41
43
|
```VB
|
|
42
44
|
Dim adapter As New TestDataSetTableAdapters.BookTableAdapter
|
|
@@ -49,8 +51,11 @@
|
|
|
49
51
|

|
|
50
52
|
試した限り、Fillメソッドの実行結果が、FillByメソッドの実行結果によって、上書きされて変数dtに格納されていたため、"追加"というのがどういう意味で使っていらっしゃるのかが分かりませんでした。
|
|
51
53
|
|
|
52
|
-
>そもそも「単にデータベースからデータを取得して、その値によって処理を分岐」という目的に型付 DataSet / DataTable + TableAdapter を使うのが適切かという話を考えるべきと思いますが、その話は今後の課題ということで・・・
|
|
54
|
+
> そもそも「単にデータベースからデータを取得して、その値によって処理を分岐」という目的に型付 DataSet / DataTable + TableAdapter を使うのが適切かという話を考えるべきと思いますが、その話は今後の課題ということで・・・
|
|
55
|
+
|
|
53
56
|
⇒初歩的な質問となり、大変お恥ずかしいのですが、「型付 DataSet / DataTable」の型付とはどういうことでしょうか。手元にある書籍には、
|
|
54
57
|
「型付きデータセットとは、データセットに具体的なデータ構造(型)を定義し、特定のテーブル(データ)を格納するために用意された専用のデータセットと思っていただければ良いでしょう」
|
|
55
58
|
と書かれておりましたが、「データセットに具体的なデータ構造(型)を定義」という説明がよく分かりませんでした。
|
|
56
|
-
ここでいうデータ構造というのは、テーブル定義(カラムやカラムに格納する型など)を表したものという認識でよろしいのでしょうか。
|
|
59
|
+
ここでいうデータ構造というのは、テーブル定義(カラムやカラムに格納する型など)を表したものという認識でよろしいのでしょうか。
|
|
60
|
+
|
|
61
|
+
質問事項が増えてしまい、申し訳ありません・・。
|
3
追記
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -25,4 +25,32 @@
|
|
|
25
25
|
' GetDataメソッドでデータを取得
|
|
26
26
|
Dim result As DataTable = adapter.GetData
|
|
27
27
|
コード
|
|
28
|
-
```
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
■追記(2021 2/20)
|
|
31
|
+
ご回答いただき、ありがとうございます。
|
|
32
|
+
|
|
33
|
+
また、情報が不足しており、申し訳ありません。
|
|
34
|
+
私が思っているより、だいぶ使い分けが難しそうですね・・。
|
|
35
|
+
|
|
36
|
+
>質問者さんの例「単にデータベースからデータを取得して、その値によって処理を分岐」で、質問者さんがそのためのカスタムクラスを作るとして、そのカスタムクラスに DataTable を渡すのにどうするかによります。そこには組織の設計思想・ルール・質問者さんの好み等々が関係するはずです。
|
|
37
|
+
⇒カスタムクラスはどういった場合に作成を検討するものなのでしょうか。
|
|
38
|
+
|
|
39
|
+
> ただ、単純に DataTable が返ってくればいいということではなく、Fill メソッドの戻り値が欲しいとか、既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。
|
|
40
|
+
⇒「既存の DataTable に追加するようにしたい場合は Fill を使うということになると思います。」と記載していただきましたが、"追加"ということは、以下のように異なるSelect文をFillメソッド、FillByメソッドで実行した際に、DataTableを表す変数dtに、それぞれの実行結果が"追加"されるということでしょうか。
|
|
41
|
+
```VB
|
|
42
|
+
Dim adapter As New TestDataSetTableAdapters.BookTableAdapter
|
|
43
|
+
Dim dt As New TestDataSet.BookDataTable
|
|
44
|
+
|
|
45
|
+
' Fillメソッドでデータを取得
|
|
46
|
+
adapter.Fill(dt)
|
|
47
|
+
adapter.FillBy(dt)
|
|
48
|
+
```
|
|
49
|
+

|
|
50
|
+
試した限り、Fillメソッドの実行結果が、FillByメソッドの実行結果によって、上書きされて変数dtに格納されていたため、"追加"というのがどういう意味で使っていらっしゃるのかが分かりませんでした。
|
|
51
|
+
|
|
52
|
+
>そもそも「単にデータベースからデータを取得して、その値によって処理を分岐」という目的に型付 DataSet / DataTable + TableAdapter を使うのが適切かという話を考えるべきと思いますが、その話は今後の課題ということで・・・
|
|
53
|
+
⇒初歩的な質問となり、大変お恥ずかしいのですが、「型付 DataSet / DataTable」の型付とはどういうことでしょうか。手元にある書籍には、
|
|
54
|
+
「型付きデータセットとは、データセットに具体的なデータ構造(型)を定義し、特定のテーブル(データ)を格納するために用意された専用のデータセットと思っていただければ良いでしょう」
|
|
55
|
+
と書かれておりましたが、「データセットに具体的なデータ構造(型)を定義」という説明がよく分かりませんでした。
|
|
56
|
+
ここでいうデータ構造というのは、テーブル定義(カラムやカラムに格納する型など)を表したものという認識でよろしいのでしょうか。
|
2
質問内容の追記
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -8,4 +8,21 @@
|
|
|
8
8
|
|
|
9
9
|
このFillメソッドとGetDataメソッドの使い分けはどのようにすれば良いのかが分かっておりません。
|
|
10
10
|
|
|
11
|
-
上記の2つのメソッドはどのように使い分けるべきなのでしょうか。
|
|
11
|
+
上記の2つのメソッドはどのように使い分けるべきなのでしょうか。
|
|
12
|
+
|
|
13
|
+
■追記(2021 2/19)
|
|
14
|
+
例えば、Webアプリを作成する際に、以下のようにxsdファイルにTableAdapterを定義したとします。
|
|
15
|
+

|
|
16
|
+
|
|
17
|
+
そして、以下のようにFillメソッドまたはGetDataテーブルを使うことで、どちらともテーブルからデータを取得することができると思いますが、この2つのメソッドの使い分けがまだ理解できておりません。
|
|
18
|
+
```VB
|
|
19
|
+
Dim adapter As New TestDataSetTableAdapters.BookTableAdapter
|
|
20
|
+
Dim dt As New TestDataSet.BookDataTable
|
|
21
|
+
|
|
22
|
+
' Fillメソッドでデータを取得
|
|
23
|
+
adapter.Fill(dt)
|
|
24
|
+
|
|
25
|
+
' GetDataメソッドでデータを取得
|
|
26
|
+
Dim result As DataTable = adapter.GetData
|
|
27
|
+
コード
|
|
28
|
+
```
|
1
不要な文言の削除
title
CHANGED
|
File without changes
|
body
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
|
|
5
5
|
xsdファイルにツールボックスからTableAdapterをドラッグアンドドロップすると、TableAdapter 構成ウィザードが表示されますが、そのときにFillメソッドとGetDataメソッドを作成することができると思います。(メソッド名は、任意)
|
|
6
6
|
|
|
7
|
-

|
|
7
|
+

|
|
8
8
|
|
|
9
9
|
このFillメソッドとGetDataメソッドの使い分けはどのようにすれば良いのかが分かっておりません。
|
|
10
10
|
|