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

SQL サブクエリー(副問い合せ)を使い、最大値の行を表示してみる

テーブル名:kounyu
ID no  名前       金額  数量
1  100 Ken3       2000     5
2   20 けんぞう    100   200
3  250 あいうえお 1500   100
5    5 かきくけこ   55    55
6   10 さしすせそ   60   150

とデータがあった時に、
・一番多く購入した人のデータ(数量が多い人)
を検索する場合
  '数量が一番大きい人を探すため、
  'MAX関数を埋め込んだサブクエリー付のSQL文を作成する
  strSQL = "Select 名前 "
  strSQL = strSQL & " From kounyu "
  strSQL = strSQL & " Where 数量 = (Select MAX([数量]) From kounyu)"
と、サブクエリーで条件を付けたSQL文を作成してみた。
詳細はソースファイルを見てください。
noが一番大きい人は[あいうえお]さんです
数量が一番大きい人は[けんぞう]さんです


DB内のデータを確認
DB:db089.mdb
確認用に発行したSQL:Select * From kounyu
IDno名前金額数量
1100Ken320005
220けんぞう100200
3250あいうえお1500100
55かきくけこ5555
610さしすせそ60150

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

サブクエリーを使用したサンプル(ソースの紹介)

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

サブクエリー を 使った ソースコードを紹介する

表示色の説明:ASP VBScriptは <% 〜 %>
キーワードはサブクエリー です。 <%@LANGUAGE=VBScript%> <html> <head> <title>SQL サブクエリー(副問い合せ)を使い、最大値の行を表示してみる</title> </head> <body> <h1>SQL サブクエリー(副問い合せ)を使い、最大値の行を表示してみる</h1> <pre> テーブル名:kounyu ID no 名前 金額 数量 1 100 Ken3 2000 5 2 20 けんぞう 100 200 3 250 あいうえお 1500 100 5 5 かきくけこ 55 55 6 10 さしすせそ 60 150 とデータがあった時に、 ・一番多く購入した人のデータ(数量が多い人) を検索する場合 '数量が一番大きい人を探すため、 'MAX関数を埋め込んだサブクエリー付のSQL文を作成する strSQL = "Select 名前 " strSQL = strSQL & " From kounyu " strSQL = strSQL & " Where 数量 = (Select MAX([数量]) From kounyu)" </pre> と、サブクエリーで条件を付けたSQL文を作成してみた。<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("db089.mdb") db.open 'データベースを開く 'noが一番大きい人を探すため、 'MAX関数を埋め込んだサブクエリー付のSQL文を作成する strSQL = "Select 名前 " strSQL = strSQL & " From kounyu " strSQL = strSQL & " Where [no] = (Select MAX([no]) From kounyu)" Set rs = db.Execute(strSQL) 'SQL発行、レコードセットの作成 'データの表示 Response.Write "noが一番大きい人は[<b>" Response.Write rs("名前") & "</b>]さんです<br>" rs.Close '使い終わったのでクローズ '数量が一番大きい人を探すため、 'MAX関数を埋め込んだサブクエリー付のSQL文を作成する strSQL = "Select 名前 " strSQL = strSQL & " From kounyu " strSQL = strSQL & " Where 数量 = (Select MAX([数量]) From kounyu)" Set rs = db.Execute(strSQL) 'SQL発行、レコードセットの作成 'データの表示 Response.Write "数量が一番大きい人は[<b>" Response.Write rs("名前") & "</b>]さんです<br>" rs.Close '開いていたレコードセットを閉じる db.Close 'データベースも閉じようよ Set db = Nothing 'お行儀よくオブジェクトも開放しましょう %> <hr> </body> </html>

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

プログラミングと関係あるような無いような、ビジネス・経済の雑誌を紹介します。
  1. 株式にっぽん 2008年 5/15号
  2. 日経ビジネス Associe (アソシエ) 2008年 5/20号
  3. 起業塾 2008年 06月号
  4. 東洋経済 統計月報 2008年 06月号
  5. 近代セールス 2008年 5/15号
  6. オール投資 2008年 5/15号
  7. バンクビジネス 2008年 5/15号
  8. 食品工業 2008年 5/30号
  9. 経済 2008年 06月号

人気の書籍を紹介します

  1. [4000029932]- 『世界』主要論文選―1946-1995
  2. [4408451509]- それって、立派な「うつ」ですよ―自分を責める人たちの処方箋
  3. [4479840699]- 東アジアの巨大古墳
  4. [4845104571]- 大きな学力
  5. [4642056513]- 古代インド文明の謎 (歴史文化ライブラリー 251)
  6. [4492042091]- 韓国はドラマチック2――ドラマ&映画スターでみる韓国スタイル

Googleで関連項目を検索する

LANGUAGE=VBScript + [キーワード:サブクエリー] 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/12 17:05:36です。
[Topへ戻る] −−>[ASP系へ戻る] −−>[バックナンバーを見る]