SQLServerが利用できない環境にデータを持っていくため、以下のようなシステムを考えております。(テーブルのリンクは不可・手動でのデータのエクスポートは不可)
1.ACCESSのフォームに「データベース名」「テーブル名」を入力し、実行ボタン押下
2.ADOでSQLServerに接続
3.指定のテーブルと同じ構造のテーブルをACCESSに作成
4.SQLServerのデータをACCESSにINSERT
ここで質問なのですが、ACCESSは自分のデータベースとSQLServerのデータベースに同時に接続できますか?
同時接続した場合のACCESS/SQLServerの書き分けはどのようになるのでしょうか。
No.1ベストアンサー
- 回答日時:
普通に同時接続できるかと思います。
ちょっと手元に環境がないので間違いがあるかもしれませんが以下のような感じでしょうか。
ようは各データベース用にそれぞれ変数を用意してあげれば済むことかと。
Dim accessdb As Database
Dim sqldb As ADODB.Connection
Set accessdb = CurrentDb
Set sqldb = New ADODB.Connection
sqldb.open()
それぞれのDBに対して処理する
アドバイスありがとうございます。なるほど、片方はCurrentDBで接続、片方はADOで接続すればよいのですね。この二つを同時に一つのSQL文で扱うことはできるでしょうか?「Insert into accessDB.ユーザーマスタ Select sqldb.ユーザーマスター」みたいな。
No.3
- 回答日時:
#1です。
>この二つを同時に一つのSQL文で扱うことはできるでしょうか?
これはさすがに無理ではないかと思います。
2のお礼で書かれているようにSQLServerのデータをレコードセットに取り、1レコードずつInsertするしかないと思います。
回答ありがとうございます。あれから試行錯誤いたしまして、マクロ→データベース変換でODBCドライバを使用することにより、簡単にテーブルデータを取り込めるようになりました。何度もお返事ありがとうございました。
No.2
- 回答日時:
>ACCESSは自分のデータベース・・に接続できますか?
自分のとはカレントDB?ということですか?それとも他のAccessファイルにADOで接続するということですか?
カレントDBからADOでSQLServerに接続すればカレントDB内で処理できますが。
もしくは#1の方のいうように変数を宣言してカレントDBを変数にセットすればいいのでは。
Dim acdb As Database
Set acdb = CurrentDb のように。
’SQLServerに接続
Dim cnn As New ADODB.Connection
Dim rec As New ADODB.Recordset
' 接続を確立させる。
cnn.Open "Provider=SQLOLEDB;" & _
"Data Source=サーバー名;" & _
"Initial Catalog=サーバ上のデータベース名;", "sa", ""
’SQLを指定してレコードセットを作成する。
rec.Open "select * from テーブル名", cnn, _
adOpenKeyset, adLockOptimistic
他のAccessファイルに接続する場合はProvider=Microsoft.Jet.OLEDB.Jetのバージョン
に変えて接続を確立すれば出来ます。
質問内容と違っていたらゴメンなさい。
回答ありがとうございます。#1さんのお礼欄にも書いたのですが、一つのSQL文で同時に扱うことはできますでしょうか?それともSQLServerのデータをレコードセットに取り、1レコードずつInsertするしかないでしょうか。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
準・究極の選択
「年収1000万円で一生カレーライス」か 「年収180万円で毎日何でも食べ放題」 あなたはどちらを選びますか?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
アクセスVBAで既に開いているエクセルを閉じたい
Yahoo!ショッピング
-
Access サブフォームでの選択行の取得
その他(データベース)
-
フォームを開くときに、コンボボックスの値を選択(アクセスVBA)
Visual Basic(VBA)
-
-
4
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
5
Accessのフォーム上でSQLServerのデータを更新・追加する方法
その他(プログラミング・Web制作)
-
6
Accessを開きなおすとテキストボックスの値がエラー#Name?になる
その他(データベース)
-
7
パススルークエリ&ACCESSテーブル VBA抽出方法
SQL Server
-
8
アクセスでテキストボックスの値が空白だったら
Access(アクセス)
-
9
falseとtrue 0,1,-1 の意味が知りたいです
PowerPoint(パワーポイント)
-
10
ACCESS 複数のフォームから同一テーブル参照
Access(アクセス)
-
11
テキストボックスにクエリ結果を表示させたい
その他(データベース)
-
12
DAOでのOpenRecordsetの方法
SQL Server
-
13
どこにもフォーカスを当てたくない
Access(アクセス)
-
14
ラベルとテキストボックスのグループ化を解除したい
Access(アクセス)
-
15
テーブルリンク リンク元を知りたい
Access(アクセス)
-
16
別のDBからテーブルをコピーする方法
SQL Server
-
17
パススルークエリをテーブル作成するには?
その他(データベース)
-
18
Accessで検索を高速化
Access(アクセス)
-
19
実行時エラー -2147217900 ADODBでレコードセットオープン時エラー
Access(アクセス)
-
20
ACCSESS2013VBA フォームのレコードソースを変更する
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
DB接続ができなくなって困って...
-
ACCESSからSQLServerのデータを...
-
タイムアウト
-
Access から SQLserver に接続...
-
ACCESSからのODBC接続のみ応答...
-
SQLで同じDBに対し2つのコネク...
-
AccessからMysSqlにODBC経由で...
-
Access ユーザーレベルセキュ...
-
Oracle 8i コンマ(,)を含むデ...
-
ノートパソコンのHDDを同機種へ...
-
VBのソース上からAccessのmdbフ...
-
オブジェクト名 '<table>' が無...
-
リンクサーバ(PostgreSQL)に...
-
ACCESS ADOでupdateが効かない
-
Excel-VBAの「しばらくお待ちく...
-
DTexec でSSISパッケージを実行...
-
ユーザー定義関数内でのsp_exec...
-
SQLサーバー接続について
-
ACCESS2000ディスクまたはネッ...
-
SQL Loaderを使いたい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
DB接続ができなくなって困って...
-
drop user できない。ORA-01940
-
ACCESSからのODBC接続のみ応答...
-
ACCESSからSQLServerのデータを...
-
Access から SQLserver に接続...
-
SQLで同じDBに対し2つのコネク...
-
ACCESS ODBC 接続ダイアログ 非...
-
SQL Serverの移行について
-
IBM系のDBでIMSに関して
-
VBでODBC接続して更新・削除で...
-
SQLServer,接続失敗時のエラー...
-
SQLserverとMSDEにていて
-
クライアントでの処理が遅い
-
別の所にある(グローバルIPが...
-
ACCESS VBAでサーバー起動して...
-
VB6.0(SP6)でMySQLに接続したい
-
SQLServer認証とWIndows認証
-
cseでロリポップのDBに接続は可...
-
RDO と DAO の違いについて(S...
-
SQLSERVERの接続方法を教えて下...
おすすめ情報