MS Access

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

投稿日:2014年6月23日 更新日:

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

これはこれで便利なのだが、ユーザーから、ひとりの人がAccessを使っている間、もう一方の人がリンクテーブル先のブックをExcelで開こうとすると「編集のためロックされています」のメッセージが出る。
Excelは読み取り専用でしか開けないので、編集するケースはないのだが、Accessではそういってくる。
リンクテーブルを読んであれこれする業務は月に数度しかないのに、誰かがAccessのmdbを開いているだけでもその間、もう一方は閉じるのを待っていなければならない。これを何とかして欲しい・・・と、ずっと要望を受けていた。
しかし、いろいろ調べては見たものの、それを現在使っていなくてもExcelブックをリンクテーブルにしているだけでロックされるのは、なんともならないとずっと思っていて、そのように説明していた。

けども、以下のようなやり方があったとは。

リンクテーブルにせずにExcelシートをクエリで使う。 | MS Access Scrapbook

早速このやり方を使ってみた。
自分の業務だと、こんな感じ。

'Excel
SELECT * FROM [EXCEL 12.0;HDR=Yes;
DATABASE=C:\Users\Documents\スケジュール.xlsm].[全体$];

'CSV text
SELECT * FROM [Text;HDR=Yes;
FMT=Delimited;DATABASE=c:\test].[rakuraku_item.csv];

クエリを実行中は、確かに今まで通りになるが、実行していない間は、これまでのようにExcelで該当ブックを開こうとしても、ロックのメッセージが出なかった。
しかも、一方のExcelブックを現在編集中で保存していなくても、Accessでクエリを実行すると何事もなく開き、それまで編集中の内容がクエリに表示されている・・・!

これは役立つ情報だ!!
情報源の方に感謝!

2021/4/14(水)追記:
Excelファイルに加え、CSVテキストファイルをクエリとして読むコードを追加!

-MS Access

執筆者:

関連記事

no image

Accessでメッセージ内容が無い(のっぺらぼう、OKボタンのみ)エラーメッセージがでる

自分作のモジュールの記述で、以下のように書いている箇所があって、 If rs.EOF = True Then GoTo Err_chkFukuyamaVcr ‘error Else   (中略) また …

Access「実行時エラー3061 パラメータが少なすぎます。2を指定してください」で意外な決着

クロス集計クエリをVBAで読むときで、かつパラメータクエリを使う場合には、クエリのパラメータパネルで、別途、パラメータを指定しなくてはならない(VBAで使わないなら不要) 本日のトラブルは、その後、W …

no image

Accessで、見積書のような「サブフォームつきフォームを丸々コピー」する方法・・・見つけるのに、四苦八苦。

最初、複雑でかつ読み取り専用のクエリを元にしたフォームをコピーしようとしていたために、 acCmdPasteAppendのラインで「コマンドまたはアクション”追加貼り付け”は無効です」のエラーが出て、 …

no image

ドメインのDNSの管理会社を移転したら、BASP21でSMTP送信がエラー

CPIも、BASP21も、どちらもマイナー(笑)なので、誰の役にも立たないかもしれないけど、自分の備忘録として、残します。 これまでCPIでWebもメールも動かしていたが、WebのみをShopifyに …

no image

Accessでファイル選択ダイアログを開いて選択したExcelファイルの先頭シートを読み込み番号が一致するデータの配送日を本日日付で消し込む処理

ファイル選択ダイアログを開いて、選択したExcelファイルの先頭シートを読み込み、番号が一致するデータの配送日を本日日付で消し込む処理(楽天販売DB.mdb) ダイアログを表示する際には、事前にMic …