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

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

新規登録して質問してみよう
ただいま回答率
85.48%
データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

4回答

5282閲覧

伝票ごとの合計金額をヘッダテーブルに持たせるか?

jk233

総合スコア55

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2015/05/22 06:07

伝票をシステム化します。

現状の伝票仕様
・伝票には1枚ごとに伝票番号、税率があります。
・伝票には明細が5行あります。
・明細行それぞれに対して単価、数量を指定することができます。

伝票をヘッダテーブルと明細テーブルに分けて保存するとします。
【ヘッダテーブル】伝票番号、伝票日付、取引先コード、税率 等...
【明細テーブル】伝票番号、行番号、商品コード、単価、数量 等...

明細ごとの金額は、単価×数量(四捨五入)で求められます。
伝票ごとの合計金額は、5行分を足して税率を掛けることで求められます。

いま悩んでいるのは、この伝票ごとの合計金額をヘッダテーブルに持たせるかどうかです。
算出できる項目なので、不要といえば不要ですが、あれば便利なのかなとも思います。

(あれば便利と思う理由)
・トラブル調査の際に直接テーブルを参照するような場合
・月次や年次の集計をする機能を作成する場合に、伝票ごとの合計金額を算出処理を実装しなくてよい。

皆様はどのようにされているでしょうか。
ご意見お聞かせください。

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

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

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

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

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

guest

回答4

0

元データが税抜きしかないとなれば、税込みの合計は「持つべき」でしょう。

2017年4月には消費税も上がる予定ですし、税率と税込金額を持っておかないと、移行期に税率適用ミスが発生する危険も大きいです。

投稿2015/05/22 06:56

編集2015/05/22 06:57
maisumakun

総合スコア145183

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

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

0

本来、正規化して導出項目はテーブルに持たないのが基本ですが、消費税の丸め処理などが入る可能性があるなら、持つ方が良いでしょう。

投稿2015/05/22 06:33

kantomi

総合スコア295

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

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

0

他の方が回答されているようにヘッダテーブルにも持っておいた方がよいですね。
伝票一覧を取得する時に金額をsumで都度集計していたら、処理が重たくなります。

投稿2015/05/22 11:56

selva_nakayama

総合スコア16

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

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

0

ベストアンサー

確かに冗長ですが、合計金額を検索することは多いと思われます。
インデックスをつけて検索が早くなることも期待し、伝票の合計金額を入れた方が良いと思います。
テーブルを分けるまでしなくてよいと思いますが、ヘッダテーブルに入れてはいかがでしょうか。

投稿2015/05/22 06:14

takotakot

総合スコア1111

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問