
お世話になります。
一覧の結果画面を実装中なのですが、
ラベルにselect文の結果を入れるところで詰まってしまっております。
//ラベルに結果をセットの部分です。
重大度レベル コード 説明 プロジェクト ファイル 行 抑制状態 エラー CS1061 'DataTable' に 'Text' の定義が含まれておらず、型 'DataTable' の最初の引数を受け付ける拡張メソッド 'Text' が見つかりませんでした。using ディレクティブまたはアセンブリ参照が不足していないことを確認してください。 基幹システム C:\Users\1121098\Desktop\基幹システム\基幹システム\株式関係\Kabu.cs 75 アクティブ
C#
1using System; 2using System.Collections.Generic; 3using System.ComponentModel; 4using System.Data; 5using System.Drawing; 6using System.Linq; 7using System.Text; 8using System.Threading.Tasks; 9using System.Windows.Forms; 10 11namespace 基幹システム.株式関係 12{ 13 public partial class kabu : Form 14 { 15 public kabu() 16 { 17 InitializeComponent(); 18 } 19 20 private void kabu_Load(object sender, EventArgs e) 21 { 22 //DB接続等 23 string dbPath = Application.StartupPath + @"\kabukanri.db"; 24 using (SQLiteConnection con = new SQLiteConnection("Data Source=" + dbPath)) 25 { 26 DataTable datatable = new DataTable(); 27 #region 画面ロード時に初期表示するためのSQL 28 SQLiteDataAdapter adapter = new SQLiteDataAdapter 29 ("select " + 30 "損益テーブル.日付 ||(曜日テーブル.曜日) as 日付" + 31 ",損益テーブル.損益額" + 32 ",コメントテーブル.コメント from 損益テーブル left join コメントテーブル on" + 33 " 損益テーブル.日付 = コメントテーブル.日付 left join" + 34 " 曜日テーブル on 損益テーブル.曜日ID = 曜日テーブル.ID; ", con); 35 adapter.Fill(datatable); 36 #endregion 37 this.dataGridView1.DataSource = datatable; 38 39 #region 画面ロード時に初期表示するためのSQL 40 //ヘッダーを変更 41 dataGridView1.Columns[0].HeaderText = "日付"; 42 dataGridView1.Columns[1].HeaderText = "損益額"; 43 dataGridView1.Columns[2].HeaderText = "コメント"; 44 #endregion 45 46 #region 当月の損益サマリークエリ 47 using (SQLiteTransaction trans = con.BeginTransaction()) 48 { 49 DataTable datatable2 = new DataTable(); 50 StringBuilder tougetu = new StringBuilder(); 51 SQLiteCommand cmd = con.CreateCommand(); 52 53 tougetu.AppendLine("select SUM(損益額) from 損益テーブル"); 54 tougetu.AppendLine("where 日付 >= @日付From"); 55 tougetu.AppendLine("and 日付 <= @日付To"); 56 57 cmd.Parameters.Add("日付From", System.Data.DbType.String); 58 cmd.Parameters.Add("日付To", System.Data.DbType.String); 59 60 DateTime dtToday = DateTime.Today; 61 //月初 62 DateTime dtFDM = new DateTime(dtToday.Year, dtToday.Month, 1); 63 //月末 64 DateTime dtLDM = new DateTime(dtToday.Year, dtToday.Month, 65 DateTime.DaysInMonth(dtToday.Year, dtToday.Month)); 66 67 cmd.Parameters["日付From"].Value = dtFDM; 68 cmd.Parameters["日付To"].Value = dtLDM; 69 70 cmd.CommandText = tougetu.ToString(); 71 72 //ラベルに結果をセット 73 adapter.Fill(datatable); 74 this.lblsumTougetu.Text = datatable.Text; 75 } 76 #endregion 77 } 78 } 79 //検索ボタンを押下したときの処理 80 private void btnserch_Click(object sender, EventArgs e) 81 { 82 //DB接続等 83 string dbPath = Application.StartupPath + @"\kabukanri.db"; 84 using (SQLiteConnection con = new SQLiteConnection("Data Source=" + dbPath)) 85 { 86 DataTable datatable = new DataTable(); 87 #region 検索時項目が入っている場合のSQL 88 SQLiteDataAdapter adapter = new SQLiteDataAdapter 89 ("select" + 90 " 損益.日付||曜日.曜日," + 91 "損益.損益額," + 92 "コメント.コメント" + 93 " from" + 94 " 損益テーブル 損益" + 95 " left join 曜日テーブル 曜日" + 96 " on 曜日.ID = 損益.曜日ID" + 97 " left join コメントテーブル コメント" + 98 " on コメント.日付 = 損益.日付" + 99 " where " + 100 "1=1" + 101 "and 損益.日付 >= '@'" + 102 " and 損益.日付 <= '@'" + 103 " and 損益.損益額 >= '@'" + 104 " and 損益額 <= '@';", con); 105 #endregion 106 adapter.Fill(datatable); 107 this.dataGridView1.DataSource = datatable; 108 } 109 } 110 #region 損益登録画面に遷移 111 private void button1_Click(object sender, EventArgs e) 112 { 113 114 基幹システム.株式関係.KabuTouroku2 KabuTouroku2 = new 株式関係.KabuTouroku2(); 115 KabuTouroku2.Show(); 116 this.Visible = false; 117 } 118 #endregion 119 } 120} 121

エラーメッセージにあるように、DataTableの定義に、Textメソッドなどがあるか定義を確認してみてください。質問文に追記できますか?

回答1件
あなたの回答
tips
プレビュー