2016-06-16 8 views
0

Active Directoryにアクセスして、ユーザーおよびその他のフィールドをAccessに照会しています。クエリされた結果を既存のテーブルに追加する方法はありますか?現時点では、INSERT INTOを使用しようとしていますが、Object変数が設定されていない、または変数をブロックしている問題が発生しています。Accessでテーブルに照会されたレコードセットを追加します。

Private Sub Command0_Click() 

Dim objRecordSet As Object 
Dim objCommand As Object 
Dim objConnection As Object 
Dim dbs As Database 

Const ADS_SCOPE_SUBTREE = 2 

Set objConnection = CreateObject("ADODB.Connection") 
Set objCommand = CreateObject("ADODB.Command") 
objConnection.Provider = "ADsDSOObject" 
objConnection.Open "Active Directory Provider" 
Set objCommand.ActiveConnection = objConnection 

objCommand.Properties("Page Size") = 1000 
objCommand.Properties("Searchscope") = ADS_SCOPE_SUBTREE 
objCommand.Properties("Sort On") = "whenCreated" 

objCommand.CommandText = _ 
"SELECT Name,Title,PhysicalDeliveryOfficeName,WhenCreated,Mail FROM 'LDAP://OU=Standard Users,OU=Active Users,OU=All Users,DC=contoso,dc=local' WHERE objectCategory='user'" 
Set objRecordSet = objCommand.Execute 

objRecordSet.MoveFirst 
Do Until objRecordSet.EOF 
    dbs.Execute " INSERT INTO ADUsers" & "(Name,Title,Site,Created,Email) VALUES " & "(objRecordSet.Fields('Name').Value,objRecordSet.Fields('Title').Value,objRecordSet.Fields('physicalDeliveryOfficeName').Value,objRecordSet.Fields('whenCreated').Value,objRecordSet.Fields('Mail').Value);" 
    dbs.Close 
    Debug.Print objRecordSet.Fields("Name").Value; "," & objRecordSet.Fields("Title").Value; "," & objRecordSet.Fields("physicalDeliveryOfficeName").Value; "," & objRecordSet.Fields("whenCreated").Value; "," & objRecordSet.Fields("Mail").Value 

objRecordSet.MoveNext 

Loop 

End Sub 

答えて

0

内部のすべては"は(objRecordSet.Fields("myFieldName").Valueの値)はinsert文で引用する必要がないコードや文字列として文字列として解釈される二重引用。

文字列内のSQL文
dim strSQLInsert as String 

strSQLInsert = "INSERT INTO ADUsers(Name,Title,Site,Created,Email) VALUES ('" & _ 
    objRecordSet.Fields("Name").Value & "','" & _ 
    objRecordSet.Fields("Title").Value & "','" & 
    objRecordSet.Fields("physicalDeliveryOfficeName").Value & "','" & _ 
    objRecordSet.Fields("whenCreated").Value & "','" & _ 
    objRecordSet.Fields("Mail").Value & "');" 

Debug.Print strSQLInsert 

dbs.Execute strSQLInsert 

ストア、あなたはDebug.Printでそれを確認することができます。

0

引用符の必要を避けるために、querydefsを使用してパラメータ化されたクエリを検討してください。また、主な問題であるかもしれないデータベースオブジェクトを必ず初期化してください:set dbs = CurrentDb

... 
Dim strSQL As String 
Set dbs = CurrentDb 

strSQL = "PARAMETERS NameParm TEXT(255), TitleParam TEXT(255), SiteParam TEXT(255)," _ 
      & " CreatedParm Date, EmailParam TEXT(255);" _ 
      & " INSERT INTO ADUsers (Name, Title, Site, Created, Email)" _ 
      & " VALUES ([NameParm], [TitleParam], [SiteParam], [Created], [Email]);" 

Do Until objRecordSet.EOF 

    Set qdef = dbs.CreateQueryDef("", strSQL) 

    qdef!NameParam = objRecordSet![Name] 
    qdef!TitleParam = objRecordSet![Title] 
    qdef!SiteParam = objRecordSet![PhysicalDeliveryOfficeName] 
    qdef!CreatedParam = objRecordSet![WhenCreated] 
    qdef!EmailParam = objRecordSet![Mail] 

    qdef.Execute (dbfailOnError) 
    Set qdef = Nothing 

    objRecordSet.MoveNext 
Loop 
関連する問題