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

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

ただいまの
回答率

90.36%

  • MySQL

    6521questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Delphi

    20questions

    DelphiはPascalを拡張してオブジェクト指向を導入したWindows, OS X,iOS,Androidのネイティブアプリケーションを開発するための言語です。旧称はObject Pascal。開発用IDE「Delphi」にあわせ現在の名前に改称されました。

Delphi 集計フィールドがエディットコンポーネントに反映されない

解決済

回答 2

投稿 編集

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

rozeo

score 8

前提・実現したいこと

Delphiでグリッドの集計データをエクセルに出力しています。
新規フィールド作成にて「集計」フィールドを作成してカラムの合計値を出力したいのですが、フィールドがNullのままで出力出来ない状態です。

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

エラーメッセージは特にありません。

該当のソースコード

プロパティ等で操作しているため、ソースコードはありません。

試したこと

フィールドエディタから該当の集計フィールドのプロパティを操作。
Active := True
Expression := Sum(hoge)
となっております。

エクセル出力の時にデバッガを回すとどうやらフィールドの値がNullのようです。
タイトル通り、エディットコンポーネントを使って表示されるか試したところ表示されない状態です。

補足情報(FW/ツールのバージョンなど)

Delphi 10.1 Berlin
MySQL 5.7.22

必要な情報があれば追記します。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • sazi

    2019/02/12 16:03

    使用してるDBMSはoracleですか?タグに追加されると良いかと思います。

    キャンセル

  • rozeo

    2019/02/12 16:06

    ご指摘ありがとうございます。MySQLです。追記しておきます。

    キャンセル

回答 2

checkベストアンサー

0

FireDACを使用しているのであれば、集計フィールドを追加したFDQueryかFDTableのAggregateActiveプロパティをTrueに設定したら集計値取れるようにならないでしょうか

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/02/13 10:14

    http://qq2q.biz/Qjr8
    ご指摘の通りです。こちらにも同様の説明がありました。
    BAとさせていただきます。ありがとうございました。
    ちなみに、Null値が入っていても問題ないようです。

    キャンセル

0

Delphiに詳しくないので、外している可能性大です。
delphi 10.1 Berlin FireMonkeyでしょうか?

通常集計関数であるsum()の対象項目にnullが含まれているとNullになります。

グリッドのhogeに値を設定する際にnullを0に変換すればどうですか。

mysqlで値を取得しているなら、SQLで編集するのもありだと思いますけど。

select coalesce(hoge, 0) as hoge

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/02/12 17:00

    ご回答ありがとうございます。
    FireMonkeyではなくVCLを使っております。
    ご指摘の通り対象項目にNullが入っておりましたので、一度Null値の存在しないカラムにて同様の操作を確認しました。しかし、集計フィールドはNull値のままでした。
    値を0に変換を進めつつ、他の要因を探りたいと思います。

    キャンセル

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

  • MySQL

    6521questions

    MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

  • Delphi

    20questions

    DelphiはPascalを拡張してオブジェクト指向を導入したWindows, OS X,iOS,Androidのネイティブアプリケーションを開発するための言語です。旧称はObject Pascal。開発用IDE「Delphi」にあわせ現在の名前に改称されました。