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

ExcelブックをAccessで読みたいときにリンクテーブルを使わない方法があったとは・・・知らなかった

とある業務で、Access内でExcelブックをリンクテーブルで読む・・・という使い方をしてきた。 (AccessのmdbはNASにおいて共有している。Excelのxlsも同じく) これはこれで便利な …

no image

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

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

no image

SqlServer 2008 Express R2 をインストールしようとしているのだが、最後の最後でうまくいかない

前回、試しに自分の普段のPCでSqlServer2008をインストールしたのだが、今回はサーバ(といってもXP)を対象に同様のことをしてみた。 しかしインストールの最後で「there was an e …

no image

サブフォームで苦労

Access覚書。 サブフォームつきのフォームからダイアログ・フォームを呼び出す。 ダイアログフォームのリスト形式のレコードをクリックしたら、呼び出し元のフォームのサブフォームに値を追加して、次のため …

no image

VBAで英字混じりの引数から数字のみを取り出す関数

たとえば、abcABC123456XYGという引数から、123456のみを取り出したい。 VBAの組み込み関数で、適当なのがありそうだけど、無いみたい。 カスタム関数を作るにも、これはという情報がググ …