2016-06-16 4 views
0

Я запрашиваю Active Directory, чтобы вывести список пользователей и другие поля в Access. Есть ли способ добавить мои запрошенные результаты в существующую таблицу? В настоящее время я пытаюсь использовать INSERT INTO, но проблемы с моей переменной Object не устанавливаются или блокируются.Append queried Recordset to Table in 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

Все внутри doublequotes " интерпретируется как строка не как код и строки (значения objRecordSet.Fields("myFieldName").Value) должны быть указаны в заявлении вставки.

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