LoginSignup
37
44

Microsoft Accessをクラウドで運用するには、Azure SQL を使ってデータベースを共有する

Last updated at Posted at 2015-10-13

いままで Microsoft Access を使ってシステムを作成してきたのですが、遠隔地間でデータ共有を行うことは大変困難なことでした。

私が作成する小規模な業務システム(パソコン台数5~10台程度)は、Access の VBA で作成しています。そのため、今まで作成したシステムをクラウドで動作するようにするには、php言語などで作成する方法になります。そうするとほとんどのプログラムコードを書き替えないといけません。

image

Webアプリ用の言語は、HTMLとCSS程度しかわからない私は、1年前からphp言語の勉強を始めることにしました。

そうして思ったことを「JavaとJavaScriptの違いもわからないままphp言語の勉強はじめてわかったこと」としてブログにつぶやいています。お時間の許す方は、お立ち寄りください。
http://excel-databace.hatenablog.com/entry/java_javascript

結局のところ、phpからASP.NETを経て、Access・ExcelとAzure SQLで運用する結論に至りました。現在では、100社ほどのユーザー様にご利用いただいております。

現在のプログラムを活用して、Access をクラウド化する。

以前は、SharePointで Access Database を共有していましたが、現在では、Azure SQL Database で共有しています。

【SharePoint から Azure SQL Database に変更した理由】
1.すべての端末PCに、Office 365 の アカウントが必要
2.ローカルPCの処理と SharePoint の更新に微妙なずれがありレコードが競合することがある。
3.データベースの移動作業の作業料が多い。

Azure SQL Database で、共有する場合

Azure SQL Database を利用して共有したアプリが、[クラウドデータベース GANSO]です。
内容につきましては、逐次紹介していきます。

20181018_1.png

以下に、SharePointで共有する方法を記載していますが、あまりお勧めはしません。
[クラウドデータベース Ganso]を公開しましたので、上のリンク先からダウンロードしてください。

SharePointで共有する場合

・要望

1.いままでのプログラムコードをできるだけ再利用する。
2.システムやデータの移行が簡単に行える。
3.サーバーなどの運用環境の構築やランニングコストをできる限り抑える。

・現在のシステム運用環境

1.拠点ごとのパソコン台数は、5台程度
2.遠隔地の拠点数は、3拠点程度(現在VPNは構築していない)合計15台で運用
3.運用中のデータベースは、SQLデータベースとAccessのデータベースがローカルごとに混在している

・今後のシステム運用環境

1.ローカル環境で Windows Server は使わない。データ共有は NAS に Access のデータベースを置いて運用する。
2.遠隔地間で共有するデータは、Office365 の Share Point Online を利用する。
3.フロントツールは、Microsoft Access を使用して Office365 の Share Point Online リンクテーブルを使用する。
4.VPN の構築と One Drive の利用を比較検討

Access のリンクテーブルは下図のような感じになります。

通常のリンクテーブルと同じようにOffice365のSharePointのカスタムリストにリンクテーブルを作成します。
image

Office365のSharePointでは下図のように管理されています。

リンクテーブルは、Office365のサイトコンテンツとして管理されています。
image

このような方法だと、プログラムコードは現在の VBA をほぼ再利用でき、システムの移行作業も簡単です。ただし、それぞれのパソコンにはAccessが必要になりますが、Microsoft から無料で配布されているMicrosoft Access 2013 ランタイム版で実行することができます。

▼例えば、Office365で作成したテーブルをAccessにリンクするには、
image

Office365の作成したサイトを指定して
image

リストをクリッックするだけでリンクテーブルが作成されます。
image
こんなに簡単に業務システムをクラウド化できるのに、なぜ皆さんやらないのでしょうか?

今後の業務システムでは、クラウド環境で運用することは当然のごとく必須条件です。いままでの VBA のプログラムでは限界があるのですが、どのようにして低コストでシステムをクラウド環境に移行するかポイントになります。

Office 365 や Azure を利用して、移行することが望ましいと思います。

SharePoint から、Azure SQL データベースに移行しました。

Shrepoint を使って、2年ほど運用してきましたが、データベースをWebで活用するのがいま一つ大変なので、Azure SQL データベースに変更しました。

大きな理由は、次の点です。

  1. ASP.NET で データベースを活用できない。
  2. ユーザーが、Office 365 の Sharepoint を利用できるアカウントが必要になる。
  3. Sharepoint のカスタムリストを他のアカウントに移動する場合の多くの作業時間が必要になる。

AccessとExcelを連携してクラウドシステムを作成する

データベースをAzure SQL にセットして、AccessやExcelのプログラムから データベースを遠隔地間で共有するシステムを公開しています。


http://access-cloud.hatenablog.com/entry/database

image.png

37
44
7

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
37
44