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

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

新規登録して質問してみよう
ただいま回答率
85.50%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

1回答

6396閲覧

SQL文の結果をラベルにセットしたい

yamaguti

総合スコア185

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2017/04/24 08:47

編集2017/04/24 08:55

お世話になります。

一覧の結果画面を実装中なのですが、
ラベルに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

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/04/24 09:00

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

回答1

0

ベストアンサー

DataTable datatable2 = new DataTable();
datatable2 で宣言しているのに

this.lblsumTougetu.Text = datatable.Text;
datatableになってますね。

投稿2017/04/24 09:03

jm1156

総合スコア866

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問