MS Access

Accessで複数レコードを1レコードにまとめる(運送会社送り状作成のため

投稿日:

Accessに入れてある楽天の注文データをもとに、運送屋さんの送り状伝票を作ろうと思い立った。
しかし、楽天の注文データは、同一の受注番号で複数の商品に分かれている。
例えば一人の人が3点買い物をしたら、レコードは3つできている。
このレコードを一つにまとめて、商品1、商品2・・・商品9というフィールドにそれぞれ入れたい。
やりたいことはそういうことなのだが、WEBでいろんな知恵をあさっても、なかなか自分のやり方にマッチするものが出てこなかったので、自分で作ってみた。

以下、コード。

[code]
Public Function ProdHolizon(ORDERNO As String, NO As Integer)

‘[受注番号] と表示位置(1-10)をキーに商品名を取得し横展開

Dim dbs As Database
Dim rst As Recordset
Dim strSQL As String

Set dbs = CurrentDb
strSQL = "SELECT TOP 1 temp1.[商品名] FROM (select top " & NO & " [商品名] from [楽天販売TBL] WHERE [受注番号] = ‘" & ORDERNO & "’ order by [商品名]) AS temp1 ORDER BY temp1.商品名 DESC;"
Set rst = dbs.OpenRecordset(strSQL, dbOpenDynaset, dbSeeChanges)
r = DCount("ID", "楽天販売TBL", "[受注番号] = ‘" & ORDERNO & "’")
If NO > r Then
ProdHolizon = Null
Else
ProdHolizon = rst!商品名
End If
rst.Close
End Function
[/code]

上記のコードを、クエリの列にセットする。
例えば、以下のように。

商品が1から10までなら、10列分、作る。
引数は、受注番号と注文された商品名のレコード数の2つ。

実行結果は、以下。

結構、簡単にできたかな。

-MS Access

執筆者:

関連記事

no image

Access 2007 Runtime Released

とうとうこの日がきたか。 「6/26公開」「6/27ダウンロード中止」「7/20再公開」って経緯で、今日現在ダウンロードできる。 MS-Access Discovery – ニュース Ac …

Shopify(Matrixify)でスケジュール化したJobのキャンセル

どうしても方法を見つけられなかったが、ふと画面に目を落とすと、あった、方法が。 焦ると視野が狭くなって、なかなか気が付かないんだよなあ、こういうの。 You have 4 scheduled jobs …

no image

AccessからExcelフォーマットでファイルに出力するサンプルコード

Excelから外部データの接続の際に,ユーザー定義関数を含んだクエリを指定するとエラーになったので、こんなやり方で対処。 Private Sub btnB2_Click() DoCmd.OutputT …

no image

Accessで「イベントプロパティに指定した式MouseMoveでエラーが発生しました。フォームまたはレポート上のActiveX コントロールを読み込むときにエラーが発生しました。」

フォームに配置したプログレスバーコントロールの上をマウスポインタが横切ろうとすると、必ず上のエラーメッセージが表示される。 原因がわからず、対処もできず、困っていた。 Google先生も頼りにならず、 …

no image

Accessでレポートのレコードソースを動的にセットしたい

今までは、フォーム上のボタンをクリックしたら、レポートをデザインで開いてからレコードソースをセットしなければならないと思っていた。 つまり、こんなやり方をやっていた。 フォーム: [sourcecod …