質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.34%

  • VB.NET

    964questions

    Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

  • SQL Server

    615questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

  • for

    255questions

    for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

  • DataGrid

    57questions

    GUIの一種であり、データを表の形式でみることが可能です。

SQL .net

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 520

前提・実現したいこと

研修開始から1か月の未経験者です。
担当者の方から課題を頂き取り組んでいるのですが、手詰まりしました
内容は、SQLからvb.netのdatagridviewへ表示するといったものなのですが、
datagridview.datasource = datatable
といった表記は使わずに
for文を使用して表示しなければなりません。
わかりづらい説明で申し訳ありませんがよろしくお願いします。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

'①プログラム(画面)とDBを接続
'①-1.DB接続のための準備
Dim sqlCon As New SqlClient.SqlConnection()
'①-2.DB接続処理
'SQL接続設定(接続文字列の生成)
sqlCon.ConnectionString = "data source=F2111\SQLEXPRESS;initial catalog=TrainingDB_2008;user id=○○;password=○○;persist security info=True;"
'②接続開始
sqlCon.Open()
'↑ データベースに接続する処理----------------------------------------------------------------------------

'↓ 接続したデータベースのテーブルに対して、何かしらの処理を行う処理--------------------------------------
'SQL実行
Dim selectYouSQL As String = "select * from StaffInfo where Address= '東京'"    'SQLの構文
Dim sqlDa As SqlClient.SqlDataAdapter = New SqlClient.SqlDataAdapter(selectYouSQL, sqlCon)
'↑ 接続したデータベースのテーブルに対して、何かしらの処理を行う処理--------------------------------------

'↓ 接続したデータベースから取得したデータを使って画面に表示させる処理------------------------------------
Dim dtSet As DataSet = New DataSet()
sqlDa.Fill(dtSet, "StaffInfo")
Dim dtTbl As New DataTable()
dtTbl = dtSet.Tables("StaffInfo")
testDataGrid.DataSource = dtTbl

こうすると表示されるのですが、 testDataGrid.DataSource = dtTbl を使わないfor文での表示方法がわかりません。
お願いします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • Zuishin

    2017/03/23 16:08

    全部教えてもらってたら同期にも後輩にも置いて行かれますよ。データが入っているのが dtTbl で、表示するのが testDataGrid というのがわかっているなら、その二つのメソッドとプロパティを調べて for 文を使うだけじゃないですか。

    キャンセル

回答 2

+2

DataTable.Rows プロパティ
DataGridViewRowCollection.Add メソッド
これらが参考になるかと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

checkベストアンサー

+1

datagridviewにお任せせずに、自力でSQL発行、データ取得、グリッドに値設定、をしなさいってことですね。

まずはADOでデータベースを操作する必要があります。
こちらのサイトを参考にしてみてください。
http://blog.livedoor.jp/akf0/archives/51431331.html

次に上記サイトのコードにて取得した結果を出力するとなっているところで、値を取得→グリッドに設定を行います。
グリッドの操作はマニュアルなりググるなりすればたくさん見つかると思いますので、とりあえず出力するのに最低限のコードだけ書いておきます。

' 行数の設定
DataGridView1.RowCount = 2
' 列数の設定
DataGridView1.ColumnCount = 2
' セルに値設定
DataGridView1(1, 1).Value = 100


あとはこれをレコード数・カラム数にあわせてループで回せばOKです(詳しくは書きません)

追記
わからないことは担当者に聞いた方が良いです。
聞いてはいけないルールはないと思います。
逆に聞かないのに出来てしまったら、「この人は自力で作成できる実力がある」と認識され、今後のハードルが上がっていくものと思われます。
わからないことはわからない、と素直に相談した方が良いと思いますよ。
但し丸投げで「まったくわからない」と相談するのではなく、「ここまでは調べたんだけどこの先がわからない」とかある程度自分なりにやりました、という姿勢を見せるのは大事です。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • VB.NET

    964questions

    Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

  • SQL Server

    615questions

    SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

  • for

    255questions

    for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

  • DataGrid

    57questions

    GUIの一種であり、データを表の形式でみることが可能です。