回答編集履歴

2

追記&訂正

2020/07/05 07:52

投稿

退会済みユーザー
test CHANGED
@@ -112,7 +112,7 @@
112
112
 
113
113
 
114
114
 
115
- それを Page_Load で初期画面のデータを取得する際と、Button2_Click で削除後のデータを取得する際に GridView の DataSource プロパティに設定して、そのあとで GridView,DataBind() としてください。
115
+ それを Page_Load で初期画面のデータを取得する際と、Button2_Click で削除後のデータを取得する際に GridView の DataSource プロパティに設定して、そのあとで GridView.DataBind() としてください。
116
116
 
117
117
 
118
118
 

1

追記

2020/07/05 07:52

投稿

退会済みユーザー
test CHANGED
@@ -97,3 +97,139 @@
97
97
 
98
98
 
99
99
  不明点があればこの回答のコメント欄で質問してください。
100
+
101
+
102
+
103
+ **【追記】**
104
+
105
+
106
+
107
+ 下のコメント欄の 2020/07/05 16:22 の私のコメントで、「そのためには DataCatch() メソッドのコードを直した方がよさそうです。質問にあるコードは問題もあるので、その修正案と合わせて後で回答欄に追記しておきます。」と書きましたがそれを以下に書きます。
108
+
109
+
110
+
111
+ 質問者さんの DataCatch() メソッドは、(1) DataTable(または DataView)を返すように変更、(2) SELECT クエリは SELECT * FROM ... のように * は使わないで * の部分にはフィールド名を明記する、(3) 接続の Open / Close は書かないで MySqlDataAdapter に任せる(自動的に行われます)、(4) MySqlConnection の初期化のコードには using 句を使って確実に Dispose されるようにする(特に Button2_Click では必須) ・・・と言うように変更した方がよさそうです。
112
+
113
+
114
+
115
+ それを Page_Load で初期画面のデータを取得する際と、Button2_Click で削除後のデータを取得する際に GridView の DataSource プロパティに設定して、そのあとで GridView,DataBind() としてください。
116
+
117
+
118
+
119
+ 以下のような感じです。
120
+
121
+
122
+
123
+
124
+
125
+ ```C#
126
+
127
+ using System;
128
+
129
+ using System.Data;
130
+
131
+ using MySql.Data.MySqlClient;
132
+
133
+
134
+
135
+ namespace WebApplication1
136
+
137
+ {
138
+
139
+ public partial class WebForm8 : System.Web.UI.Page
140
+
141
+ {
142
+
143
+ protected void Page_Load(object sender, EventArgs e)
144
+
145
+ {
146
+
147
+ if (!IsPostBack)
148
+
149
+ {
150
+
151
+ GridView1.DataSource = DataCatch();
152
+
153
+ GridView1.DataBind();
154
+
155
+ }
156
+
157
+ }
158
+
159
+
160
+
161
+ protected DataTable DataCatch()
162
+
163
+ {
164
+
165
+ var table = new DataTable();
166
+
167
+ var query = "SELECT Id, xxx, yyy, zzz FROM tableA";
168
+
169
+ var connString = "接続文字列(省略)";
170
+
171
+ using (var connection = new MySqlConnection(connString))
172
+
173
+ {
174
+
175
+ var adapter = new MySqlDataAdapter();
176
+
177
+ adapter.SelectCommand = new MySqlCommand(query, connection);
178
+
179
+ adapter.Fill(table);
180
+
181
+ return table;
182
+
183
+ }
184
+
185
+ }
186
+
187
+
188
+
189
+ protected void Button2_Click(object sender, EventArgs e)
190
+
191
+ {
192
+
193
+ int selectV = (int)GridView1.SelectedValue;
194
+
195
+
196
+
197
+ var query = "DELETE FROM tableA WHERE Id=@Id";
198
+
199
+ var connString = "接続文字列(省略)";
200
+
201
+
202
+
203
+ using (var connection = new MySqlConnection(connString))
204
+
205
+ {
206
+
207
+ using (var command = new MySqlCommand(query, connection))
208
+
209
+ {
210
+
211
+ command.Parameters.Add("@Id", MySqlDbType.Int32);
212
+
213
+ command.Parameters["@Id"].Value = selectV;
214
+
215
+ connection.Open();
216
+
217
+ command.ExecuteNonQuery();
218
+
219
+ }
220
+
221
+ }
222
+
223
+
224
+
225
+ GridView1.DataSource = DataCatch();
226
+
227
+ GridView1.DataBind();
228
+
229
+ }
230
+
231
+ }
232
+
233
+ }
234
+
235
+ ```