Access97でグローバル変数を持ちたいと思ったのですが、
それらしきものが見つかりません。
Public変数というものがあるのですが、これはプロシージャ-単位で
しか定義できないようです。
ひとつのデータベース全体でグローバルに定義できる定数を持ちたいのです。
たとえば、データベース内で頻繁に読み込む必要があるファイルのPATH
"C:\Program Files\Netscape\Communicator\"を
固定で持っておきたい。
何か方法はないでしょうか?
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
もし、定数でいいのであれば、
標準モジュールに、
Const DATAPATH = "C:\Program Files\Netscape\Communicator\"
のように書けば、どこからでもDATAPATHと言う名前で参照することができます。
変数である必要があるのなら、同じく標準モジュールに、
Global glbDataPath as String
Public Sub PathSet()
glbDataPath = "C:\Program Files\Netscape\Communicator\"
Exit
と書いておき、AutoExecマクロのモジュールを開くでPathSetサブルーチンを呼び出せばよいと思います。
この回答への補足
すみません。基本的なことも分からずちょっと混乱しています。
プロシージャとモジュールの概念を間違っていましたので整理します。
aptivaさんのご指摘は、モジュール内で有効な手法なのでしょうか?
それとも、データベース全体(すべてのモジュール)から
参照可能なのでしょうか?
データベースの「モジュール」タブで新規にモジュールを作成しても
他のクラスモジュールから参照することができません。
基本的に標準モジュールの作成方法が間違っているような気もします!?
クラスモジュールはたくさん作成しているのですが、
標準モジュールは作ったことがありません。
基本的な質問で申し訳ありませんが、ご助言お願いします。
No.2
- 回答日時:
aptivaさんからすでに回答が出ていますが、まだ補足がないようですので代わりに私が、
標準モジュールで定義してやれば、データベース全体から参照が可能です。
具体的には、
まず、モジュールタブで新規作成をクリックして、標準モジュールを開きます。
定数として定義するなら、標準モジュールのモジュール レベルで (宣言セクション:Option Explicitの次の行に)、
Public Const DataPath As String = "C:\Program Files\Netscape\Communicator\"
と記述してやれば、定数 DataPath が使えます。
変数として定義するなら、宣言セクションに
Public DataPath As String
と記述して、Public変数を定義してやり、
さらに、以下のような Functionプロシージャをつくり、
Public Function PathSet()
DataPath = "C:\Program Files\Netscape\Communicator\"
End Function
これを AutoExecマクロで実行(プロシージャの実行でプロシージャ名に PathSet() と記述、マクロ名を“AutoExec”とする。)してやれば、データベースを開く際に、変数にパスの内容が代入されます。
HELP で、Const ステートメント、Public ステートメント、AutoExec マクロ を確認してみてください。
具体的に分かりやすくご説明していただきありがとうございました。
しかし、まったく同じようにしてもできませんでした。
でも、お蔭様で解決しました。
単純に定数名(変数名)を既にクラスモジュールでpublic宣言して使用していた
ものを使ってしまっていただけでした。
お騒がせいたしました。
そして、ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
誕生日にもらった意外なもの
みなさんがもらった誕生日プレゼントで面白いものがあったらぜひ教えてください!
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Access-VBAのPublic変数について =基本的な事です=
Visual Basic(VBA)
-
Access サブフォームでの選択行の取得
その他(データベース)
-
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
-
4
フォームを開くときに、コンボボックスの値を選択(アクセスVBA)
Visual Basic(VBA)
-
5
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
6
Accessで、フォームからフォームへ値を引き継ぐやり方
Access(アクセス)
-
7
MS Accessでフォームの「開く時」と「読込み時」のイベントの違い
Access(アクセス)
-
8
Accessのマクロでモジュールを実行させたい。
Access(アクセス)
-
9
ACCESS──メインフォームでサブフォームのレコード件数をカウントしたい
Access(アクセス)
-
10
Access 最後のレコードに到達するまでループ処理を行う方法
Access(アクセス)
-
11
ExcelのVBA。public変数の値が消える
Visual Basic(VBA)
-
12
サブフォームに対してGoToRecordするには?
その他(Microsoft Office)
-
13
ACCESSでVBAから選択クエリの抽出条件を指定したい
Access(アクセス)
-
14
Access2000 サブフォームのRecordSet取得法
Access(アクセス)
-
15
ACCESSでデータ読み取り専用を解除する方法
その他(データベース)
-
16
アクセスで数値型のフィールドにNullをいれたい
その他(データベース)
-
17
フォームウィンドウを最前面に表示したい(ACCESS)
Microsoft ASP
-
18
アクセスのフォームのビューが表示されないのですが、
その他(データベース)
-
19
「RunSQL」と「Execute」の違い
Access(アクセス)
-
20
ACCESSでコントロールソースの変更
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Access VBAで行ラベルが定義さ...
-
Accessのマクロでモジュールを...
-
エクセルVBAでUserFormを起動し...
-
【Excel VBA】 WorksheetやRa...
-
callで順に実行されるプロシー...
-
ブックオープン時にテキストボ...
-
OutlookVBAで作成したマクロに...
-
或るプロシージャの呼び出し元判定
-
excel/vba/public変数
-
ACCESS2007インポート時の空白...
-
エクセルVBAが対応できるプログ...
-
Excel VBAで「プログラム実行」...
-
DoCmd.OpenFormパラメータが表...
-
VBA プロシージャの名前の取得
-
プロシージャのexecute権限
-
エクセルVBAで条件式について
-
自作アドインのFunctionプロシ...
-
DBMS_OUTPUT.PUT_LINEを実行し...
-
Excel:ThisWorkbookオブジェク...
-
Statement ignored というエラー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Access VBAで行ラベルが定義さ...
-
Accessのマクロでモジュールを...
-
エクセルVBAでUserFormを起動し...
-
VBA プロシージャの名前の取得
-
【Excel VBA】 WorksheetやRa...
-
callで順に実行されるプロシー...
-
或るプロシージャの呼び出し元判定
-
ACCESS2007インポート時の空白...
-
Accessでグローバル変数を宣言...
-
OutlookVBAで作成したマクロに...
-
DBMS_OUTPUT.PUT_LINEを実行し...
-
excel/vba/public変数
-
Excel VBAで「プログラム実行」...
-
エクセルVBAが対応できるプログ...
-
DB2でのストアドプロシージャの...
-
ACCESS マクロをモジュールに変...
-
ブックオープン時にテキストボ...
-
Excel:ThisWorkbookオブジェク...
-
PL/SQLのエラーについて
-
エクセルのファイルを自動でFTP...
おすすめ情報