質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Access

Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

解決済

2回答

3130閲覧

SQL Server のデータを Access のテーブルから ODBC 接続して接続する場合の速度について

hos

総合スコア33

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Access

Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

1クリップ

投稿2020/01/09 00:10

編集2020/01/09 00:13

困っていること

Access上のテーブルとODBC接続したSQL Serverのテーブルを結合させた場合に、AccessがSQL Server上のデータを全件とってこようとする。

前提

SQL Server 2016 に、Microsoft Access から、ODBC接続してデータを取得しようとしています。

SQL Server側のデータは数百~数千万件くらいあります。データにはコードの列があり、
ひとつのコードあたり、数十件から数千件くらいのレコードがあります。

コードにはインデックスがはられています。

解決したいこと

多くても十件程度までのコードテーブルを、Access上に作成し、データを取得しようとすると、データを全件クライアントに取得しようとします。
SQL Server 上では結合したクエリではなく全件のクエリが流れていることが確認できました。

下記のようなSQLを、SSMSやパススルークエリで流した場合、結果は瞬時に返ってきます。

SQL

1SELECT hoge_table.* 2 FROM hoge_table -- 数百万件以上あるデータのテーブル 3 INNER JOIN fuga_table -- コード抜き出し用のテーブル 4 ON hoge_table.code = fuga_table.code 5

Access上にコードテーブルを置いてクエリデザイン画面から問い合わせを行い、パススルーと同じような速度を得る方法はないでしょうか。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

Access上にコードテーブルを置いてクエリデザイン画面から問い合わせを行い、パススルーと同じような速度を得る方法はないでしょうか。

パススルークエリーをリンクテーブルの代わりにするのが一番だったと思います。

現状のリンクテーブル名でパススルークエリー(select * from sqlserverのテーブル名)に置き換えるのが一番効率的だと思います。

但し、パススルークエリーは使用する度に都度odbcの選択とならないように、VBAでconection情報を含んだ形で作成するようにしておいた方が良いでしょう。

投稿2020/01/14 10:27

編集2020/01/14 10:28
sazi

総合スコア25188

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hos

2020/01/15 02:40

やはりそうですよね。 どうしても、Accessのクエリデザインのみでやりたいという希望がありますが、なんとかパススルークエリを組むなりしてもらうような方向で考えます。 貴重な知見が得られました。ありがとうございます。
sazi

2020/01/15 03:42

このケースはリンクテーブルがSQLServerの場合だけなんですよね。 同じMSの製品なのに。
guest

0

Access は元々少量のデータを扱うことを前提としているパーソナル・データベースです。それに大規模データベースのフロントエンドとして機能を追加されたものです。Access に大規模データベースの性能を期待するのは無理かと。

同じクルマだからといって大型ダンプと軽自動車に何トンもの荷物を同じように運べるとは思いませんよね?

投稿2020/01/09 01:08

Orlofsky

総合スコア16415

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hos

2020/01/09 01:18 編集

それはたぶん例えが違っています。 大型ダンプにある荷物を全部持ってきてより分けるのではなく、大型ダンプのところまで行って荷物をより分けて少量の荷物を持って帰れるかが知りたいのです。 どうもできそうにはないのですが。
Orlofsky

2020/01/09 01:31

質問に答えが書いてありますよね。 >下記のようなSQLを、SSMSやパススルークエリで流した場合、結果は瞬時に返ってきます。
Y.H.

2020/01/09 03:00

> 大型ダンプのところまで行って荷物をより分けて少量の荷物を持って帰れる この動作がそのままパススルークエリーですからね。
hos

2020/01/09 23:36

>質問に答えが書いてありますよね それは答えではなく前提です。 パススルーでSQL Serverのクエリを書くのではなく、Accessのクエリデザインで行ったときに、例えばAccessのコードをin句で絞ったようなクエリがSQL Server側で実行されるような作り方があるのか? というのが質問の趣旨です。
iruyas

2020/01/14 12:28

>Accessのコードをin句で絞ったようなクエリがSQL Server側で実行されるような作り方 VBAでそういうパススルークエリを作るしかないかと。 実際そういうシステムを作ったことがあります。
hos

2020/01/15 02:35

iruyasさん ありがとうございます。やはりそうですね。あきらめます。 Access でやりたい人はやっぱり Access しか使いたくないみたいでめんどくさいです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問