三流君(TOP) /ASPで遊ぶ /記事一覧

SUM Group By したテーブルをUNION ALLでつなげる

SUM Group By したテーブルを
UNION ALL 演算子でつなげ、複数テーブルをSelectしてみました
Select 商品CD, SUM(売上金額) AS 合計金額 From T_2002年売上 Group By 商品CD
 UNION ALL
  Select 商品CD, SUM(売上金額) AS 合計金額 From T_2003年売上 Group By 商品CD
   UNION ALL
    Select 商品CD, SUM(売上金額) AS 合計金額 From T_2004年売上 Group By 商品CD
これを実行すると?

商品CD合計金額
A001120
B00250
CCCC1200
A001100
CCCC500
B002250
DDDDD5000

↑あらら、年度別に集計されちまったよ
↓テストデータ↓

DB内のデータを確認
DB:db100.mdb
確認用に発行したSQL:Select * From T_2002年売上
商品CD売上金額
A001100
B00250
A00120
CCCC1200

DB内のデータを確認
DB:db100.mdb
確認用に発行したSQL:Select * From T_2003年売上
商品CD売上金額
A001100
CCCC500

DB内のデータを確認
DB:db100.mdb
確認用に発行したSQL:Select * From T_2004年売上
商品CD売上金額
B002250
DDDDD5000

コーヒーブレイク たまには寄り道、休憩も(↓広告です):
広告:[Blogで商品紹介] ← 足跡から人気を判断?
[本日発売の商品] ← 発売日が当日の商品を紹介、、、するが効果が無いので → [先週発売の商品] ← を作成して、先走らないで、少し落ち着いてみます(笑)

UNION ALLを使用したサンプル(ソースの紹介)

詳細解説は[http:/asp/backno/asp100.html]を見てください
下記、/cgi-bin/test/test100-4.aspのソース(中身)です

UNION ALL を 使った ソースコードを紹介する

表示色の説明:ASP VBScriptは <% 〜 %>
キーワードはUNION ALL です。 <%@LANGUAGE=VBScript%> <html> <head> <title>SUM Group By したテーブルをUNION ALLでつなげる</title> </head> <body> <h1>SUM Group By したテーブルをUNION ALLでつなげる</h1> SUM Group By したテーブルを<br> UNION ALL 演算子でつなげ、複数テーブルをSelectしてみました<br> <pre> Select 商品CD, SUM(売上金額) AS 合計金額 From T_2002年売上 Group By 商品CD UNION ALL Select 商品CD, SUM(売上金額) AS 合計金額 From T_2003年売上 Group By 商品CD UNION ALL Select 商品CD, SUM(売上金額) AS 合計金額 From T_2004年売上 Group By 商品CD </pre> これを実行すると?<br> <hr> <% 'ADO DB Connection オブジェクトを作成する、英文そのままじゃん Set db=Server.CreateObject("ADODB.Connection") 'データアクセスにはJet.OLEDB.4.0を使うことを設定 db.Provider = "Microsoft.Jet.OLEDB.4.0" '次に、接続DBの位置を渡すので、Server.MapPathで変換して渡す db.ConnectionString = Server.MapPath("db100.mdb") db.open 'データベースを開く 'UNION で 3つのテーブルをつなげる strSQL = "Select 商品CD, SUM(売上金額) AS 合計金額 From T_2002年売上" strSQL = strSQL & " Group By 商品CD " strSQL = strSQL & " UNION ALL " strSQL = strSQL & " Select 商品CD, SUM(売上金額) AS 合計金額 From T_2003年売上" strSQL = strSQL & " Group By 商品CD " strSQL = strSQL & " UNION ALL " strSQL = strSQL & " Select 商品CD, SUM(売上金額) AS 合計金額 From T_2004年売上" strSQL = strSQL & " Group By 商品CD " Set rs = db.Execute(strSQL) 'データの表示をテーブルで行う Response.Write "<TABLE Border='1'>" '見出しを(フィールド名を)そのまま書き込む Response.Write "<TR>" For Each fld_A In Rs.Fields 'フィールドのアイテムに対してループ Response.Write "<TH>" & fld_A.Name & "</TH>" '↑.Nameでフィールド名を表示する Next Response.Write "</TR>" 'お約束のEOFまでループは(データが無くなるまでループ)、 Do While rs.EOF = False 'レコードセットの.EOFがFalseの間 Response.Write "<TR>" '内容を表示する For Each fld_A In Rs.Fields 'フィールドのアイテムに対してループ Response.Write "<TD>" & fld_A.Value & "</TD>" '↑.Valueでフィールドの値を表示する Next Response.Write "</TR>" '次のレコードにポインタを移動する rs.MoveNext 'これを忘れると悲惨なことに、、、 Loop Response.Write "</TABLE>" 'テーブルは終わりです '後始末 rs.Close '開いていたレコードセットを閉じる db.Close 'データベースも閉じようよ Set db = Nothing 'お行儀よくオブジェクトも開放しましょう %> <hr> ↑あらら、年度別に集計されちまったよ<br> ↓テストデータ↓<br> </body> </html>

最近発売の雑誌を紹介する

音楽・テレビ・娯楽系の雑誌です。息抜き・息抜き(って、休みすぎ?)
  1. ギター・マガジン 2008年 6月号 (CD付き): ギター・マガジン編集部
  2. リズム&ドラム・マガジン 2008年 6月号 : リズム&ドラム・マガジン編集部
  3. 上方芸能 2008年 06月号
  4. テアトロ 2008年 06月号
  5. jazz Life (ジャズライフ) 2008年 06月号
  6. CD でーた 2008年 06月号
  7. WHAT'S IN (ワッツ イン) ? 2008年 06月号
  8. サウンド&レコーディング・マガジン 2008年 6月号 : サウンド&レコーディング・マガジン編集部
  9. INROCK (イン・ロック) 2008年 06月号

ソフト開発の書籍を紹介します

  1. [4887186517]- Windowsの悪のマニュアルXP
  2. [4822207951]- ソフトウェア開発データ白書〈2005〉
  3. [4797323361]- アジャイルソフトウェア開発の奥義
  4. [4274064735]- CVSによるオープンソース開発
  5. [4534031092]- 図解でわかる ソフトウェア開発のすべて―構造化手法からオブジェクト指向まで
  6. [4764902834]- ソフトウェアアーキテクチャ―ソフトウェア開発のためのパターン体系

Googleで関連項目を検索する

LANGUAGE=VBScript + [キーワード:UNION ALL] Sub|Function プログラム|プログラミング
↓で検索するとプログラムの例 Sub/Function でまとまったHP

Google

あれ?私のページが検索に載ってない(笑)一度お試しを(私のページに、また戻ってきてね(爆))

ASPでDBはMDBを使用して、SQL文を発行するサンプル

テスト実行とサンプルソース

ASP系、ADO使用、MDB接続、SQL発行、メルマガ解説リンク

[No.26 MDBファイルにアクセスしてみたADODB.Connection]
[No.27 SQL INSERT INTO文でデータの追加]
[No.28 SQL ORDER BYでデータの並べ替え]
[No.30 SQL SELECT文WHERE句を使って条件検索]
[No.32 SQL DELETE文でデータを削除してみた]

[No.33 SQL UPDATE文でデータを更新する]
[No.38 SQL GROUP BY句 で グループ化する]
[No.39 SQL GROUP BY句 で グループ化 集計結果を並べ替えする]
[No.40 MDBへのSQL文 Format関数使用]
[No.43 SQL文 HAVING句でGroup化されたレコードに条件設定する]

[No.44 MDBを使ったアンケート集計を作る]
[No.46 SQL文 SELECT WHERE句でIN演算子を使用して複数条件を選択する]
[No.47 いろいろな削除処理で遊んでみた(笑)]
[No.70 SQL Select DISTINCT キーワードで重複結果の出力をハジク]
[No.73 テーブルをつなげて商品名を取得する方法]

[No.74 演算フィールドを作成する]
[No.75 SQL UNION演算子 で 表をつなげたレコードセットの作成]
[No.76 小計・合計の表示、SQLで小細工の嵐(笑)]
[No.77 SQL AS演算子で別名管理]
[No.82 ページ単位の表示にチャレンジしてみた]

[No.83 Select TOP 20 と Select Top n PERCENT で遊ぶ]
[No.87 ADO SQL Like演算子で部分検索する]
[No.88 SQL HAVING句でSUMした値をチェックする]
[No.89 SQL 集計関数MAXと副問い合わせ(サブクエリー)]

三流解説とリンクページを紹介

ASP系の解説を項目ごとにまとめてみました

[ASP Form等を使用したデータのやり取り]
[ASP その他処理サンプル]
[ASP テキストファイル処理]
[ASP VBScript関数関係の説明]
[ASP ADOでMdbファイルを使う]
[ASP ADOでExcelと接続してみた]

その他:blogや広告↓
[日記的なblog]← あまり更新してないけど・・・
[三流なプログラムコード]← 恥ずかしいのであまり載せてないけど・・・
[通販商品の足跡を紹介] ←通販商品などを紹介してます


現在時刻は、2008/05/17 7:55:32です。
[Topへ戻る] −−>[ASP系へ戻る] −−>[バックナンバーを見る]